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Introduction 
This standard encompasses the following: 
Volume 1 
Clause 1 describes the scope. 
Clause 2 provides normative references for the entire standard. 


Clause 3 provides definitions, abbreviations, and conventions used within the entire 
standard. 


Clause 4 describes the general operating requirements of the command layer. 
Clause 5 describes the I/O registers. 
Clause 6 contains descriptions of the commands. 
Clauses 7 through 12 point to the material in Volume 2. 
Clauses 13 through 19 point to material in Volume 3. 
Volume 2 
Clause 1 describes the scope. 
Clause 2 provides normative references for the entire standard. 


Clause 3 provides definitions, abbreviations, and conventions used within the entire 
standard. 


Clauses 4, 5, and 6 point to the material in Volume 1. 
Clause 7 contains the electrical and mechanical characteristics. 
Clause 8 contains the signal descriptions. 


Clause 9 describes the general operating requirements of the physical, data link, and 
transport layers. 


Clause 10 contains describes register addressing. 
Clause 11 contains the transport protocols. 
Clause 12 contains the interface timing diagrams. 
Clauses 13 through 19 point to material in Volume 3. 
Volume 3 
Clause 1 describes the scope. 
Clause 2 provides normative references for the entire standard. 


Clause 3 provides definitions, abbreviations, and conventions used within the entire 
standard. 


Page xviii 


T13/1532D Volume 1 Revision 4b 


Clauses 4, 5, and 6 point to the material in Volume 1. 

Clauses 7 through 12 point to the material in Volume 2. 

Clause 13 contains a general overview of the serial interface. 

Clause 14 describes the serial physical layer. 

Clause 15 describes the serial link layer. 

Clause 16 describes the serial transport layer. 

Clause 17 describes the device command layer protocol for the serial interface. 
Clause 18 describes the host command layer protocol for the serial interface. 
Clause 19 describes the serial interface host adapter register interface. 


Clause 20 describes the serial interface error handling. 
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AMERICAN NATIONAL STANDARD INCITS ***-nnnn 


American National Standard 
for Information Systems — 


Information Technology — 

AT Attachment with Packet Interface - 7 — Volume 1 — Register 
Delivered Command Set, Logical Register Set 

(ATAIATAPI-7 V1) 


1 Scope 


This standard specifies the AT Attachment Interface between host systems and storage devices. It provides 
a common attachment interface for systems manufacturers, system integrators, software suppliers, and 
suppliers of intelligent storage devices. 


Volume 1 defines the register delivered commands used by devices implementing the standard. Volume 2 
defines the connectors and cables for physical interconnection between host and storage device, the 
electrical and logical characteristics of the interconnecting signals, and the protocols for the transporting 
commands, data, and status over the interface for the parallel interface. Volume 3 defines the connectors 
and cables for physical interconnection between host and storage device, the electrical and logical 
characteristics of the interconnecting signals, and the protocols for the transporting commands, data, and 
status over the interface for the serial interface. Figure 1 shows the relationship of these documents. For 
devices implementing the PACKET command feature set, additional command layer standards are listed in 
Table 1 and described in Clause 2. 


Register delivered command set Packet delivered command sets 
Command layer Logical register set See table 1 
ATAVATAPI-7 Volume 1 


Transport, link, Parallel Transport Protocols Serial Transport Protocols 
and physical and Physical interconnect and Physical interconnect 
layers ATA/ATAPI-7 Volume 2 ATA/ATAPI-7 Volume 3 


Figure 1 - ATA document relationships 
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Table 1 - PACKET delivered command sets 
Standard 


SCSI Primary Commands (SPC) 
SCSI Primary Commands - 2 (SPC-2) 
SCSI Primary Commands - 3 (SPC-3) 
SCSI Block Commands (SBC-2) 
SCSI Stream Commands (SSC) 


Multimedia Commands (MMC) 

Multimedia Commands - 2 (MMC-2) 

Multimedia Commands - 3 (MMC-3) 

Multimedia Commands - 4 (MMC-4) 

ATAPI for Removable Media (SFF8070I) 

ATA Packet Interface (ATAPI) for Streaming Tape QIC-157 revision D 


This standard maintains compatibility with the AT Attachment with Packet Interface - 6 standard 
(ATA/ATAPI-6), INCITS 361-2002, and while providing additional functions, is not intended to require 
changes to presently installed devices or existing software. 
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2 Normative references 


The following standards contain provisions that, through reference in the text, constitute provisions of this 
standard. At the time of publication, the editions indicated were valid. All standards are subject to revision, 
and parties to agreements based on this standard are encouraged to investigate the possibility of applying 
the most recent editions of the standards listed below. 


Copies of the following documents can be obtained from ANSI: Approved ANSI standards, approved and 
draft international and regional standards (ISO, IEC, CEN/CENELEC, ITUT), and approved and draft foreign 
standards (including BSI, JIS, and DIN). For further information, contact ANSI Customer Service 
Department at 212-642-4900 (phone), 212-302-1286 (fax), or via the World Wide Web at 
http://www.ansi.org. 


Additional availability contact information is provided below as needed. 


2.1 Approved references 


The following approved ANSI standards, approved international and regional standards (ISO, IEC, 
CEN/CENELEC, ITUT), may be obtained from the international and regional organizations who control them. 


2.1.1 ANSI References 


SCSI-3 Block Commands (SBC) [ANSI INCITS 306-1998] 
SCSI-3 Primary Commands (SPC) [ANSI X3.301-1997] 
SCSI-3 Streaming Commands (SSC) — [ANSI INCITS 335-2000] 
Multimedia Commands (MMC) [ANSI X3.304-1997] 


Multimedia Commands - 2 (MMC-2) [ANSI INCITS 333-2000] 

Multimedia Commands - 3 (MMC-3) [ANSI INCITS 360-2002] 

Protected Area Run Time Interface Extensions (PARTIES) [ANSI INCITS 346-2001] 
SCSI Primary Commands - 2 (SPC-2) [ANSI INCITS 351-2001] 

AT Attachment with Packet Interface Extension (ATA/ATAPI-4), [ANSI INCITS.317-1998] 


2.1.2 ISO References 
Control and Status Register (CSR) Architecture for microprocessor buses [ISO/IEC 13213:1994] 


To obtain copies of these documents, contact Global Engineering or INCITS. Additional information may be 
available at http:/Awww.t10.org and http://www.t13.org. 


2.2. References under development 

At the time of publication, the following referenced standards were still under development. For information 
on the current status of the document, or regarding availability, contact the relevant standards body or other 
organization as indicated. 

SCSI Block Commands - 2 (SBC-2) [T10/1417-D] 

SCSI Primary Commands - 3 (SPC-3) [T10/1416-D] 

ATAPI for Rewritable Media [SFF8070i] 

Multimedia Commands - 4 (MMC-4) [T10/1545D] 


For more information on the current status of the T10 documents, contact INCITS. To obtain copies of T10 or 
SFF documents, contact Global Engineering. 


2.3. Other references 
The following standards and specifications are also referenced. 
PC Card Standard, February 1995, PCMCIA (68-pin Connector) 
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For the PC Card Standard published by the Personal Computer Memory Card International Association, 
contact PCMCIA at 408-433-2273 or http://www.pc-card.org. 


CompactFlash™ Association Specification, Revision 1.4 


For the CompactFlash™ Association Specification published by the CompactFlash™ Association, contact the 
CompactFlash™ Association at http://www.compactflash.org. 


ATA Packet Interface (ATAPI) for Streaming Tape QIC-157 revision D 


For QIC specifications published by Quarter-Inch Cartridge Drive Standards, Inc., contact them at 805 963- 
3853 or http://www.qic.org. 


EIA-364-09 TP-O9C - Durability test procedure for electrical connectors and contacts 

EIA-364-13 Mating and unmating forces test procedures for electrical connectors 

EIA-364-17 TP-17B - Temperature life with or without electrical load test procedure for electrical connectors 
and sockets 

EIA-364-18 Visual and dimensional inspection for electrical connectors 

EIA-364-20 TP-20B - Withstanding voltage test procedure for electrical connectors, sockets, and coaxial 
contacts 

EIA-364-21 Insulation resistance test procedure for electrical connectors, sockets, and coaxial contacts 

EIA-364-23 Low level contact resistance test procedure for electrical connectors and sockets 

EIA-364-27 Mechanical pulse (Specified pulse) for electrical connectors 

EIA-364-28 TP-28D Vibration test procedure for electrical connectors and sockets 

EIA-364-31 Humidity test procedure for electrical connectors and sockets 

EIA-364-32 Thermal shock (temperature cycling) test procedure for electrical conectors and sockets 

EIA-364-38 TP-38B - Cable pull-out test procedure for electrical connectors 

EIA-364-41 TP-41C - Cable flexing test procedure for electrical connectors 

EIA-364-65 TP-65A Mixed flowing gas 


For EIA specifications, contact them at http:/Awww.eia.org. 
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3 Definitions, abbreviations, and conventions 


3.1 Definitions and abbreviations 


For the purposes of this standard, the following definitions apply: 


3.1.1 
3.1.2 


3.1.3 


3.1.4 


3.1.5 


3.1.6 


3.1.7 


3.1.8 


3.1.9 


3.1.10 
3.1.11 


3.1.12 


3.1.13 


3.1.14 
3.1.15 


3.1.16 


3.1.17 


3.1.18 


3.1.19 


3.1.20 


3.1.21 


ASCII Character: Designates 8-bit value that is encoded using the ASCII Character set. 
acoustics: Measurement of airborne noise emitted by information technology and 
telecommunications equipment [ISO 7779:1999(E)] 

ATA (AT Attachment): ATA defines the physical, electrical, transport, and command protocols for 
the internal attachment of storage devices to host systems. 


ATA-1 device: A device that complied with ANSI X3.221-1994, the AT Attachment Interface for 
Disk Drives. ANSI X3.221-1994 has been withdrawn. 


ATA-2 device: A device that complied with ANSI X3.279-1996, the AT Attachment Interface with 
Extensions. ANSI X3.279-1996 has been withdrawn. 


ATA-3 device: A device that complies with ANSI X3.298-1997, the AT Attachment-3 Interface. 
ANSI X3.298-1997 has been withdrawn. 


ATAIATAPI-4 device: A device that complies with ANSI INCITS 317-1998, AT Attachment Interface 
with Packet Interface Extensions-4. 


ATAIATAPI-5 device: A device that complies with ANSI INCITS 340-2000, the AT Attachment with 
Packet Interface-5. 


ATAIATAPI-6 device: A device that complies with ANSI INCITS 361-2002, the AT Attachment with 
Packet Interface-6. 


ATAIATAPI-7 device: A device that complies with this standard. 


ATAPI (AT Attachment Packet Interface) device: A device implementing the Packet Command 
feature set. 


AU (Allocation Unit): The minimum number of logically contiguous sectors on the media as used in 
the Streaming feature set. An Allocation Unit may be accessed with one or more requests. 


AV (Audio-Video): Audio-Video applications use data that is related to video images and/or audio. 
The distinguishing characteristic of this type of data is that accuracy is of lower priority than timely 
transfer of the data. 


backchannel: When transmitting a FIS, the backchannel is the receive channel. 


BER (bit error rate): The statistical probability of a transmitted encoded bit being erroneously 
received in a communication system. 


bus release: For devices implementing overlap, the term bus release is the act of clearing both 
DRQ and BSY to zero before the action requested by the command is completed. This allows the 
host to select the other device or deliver another queued command. 


byte count: The value placed in the Byte Count register by the device to indicate the number of 
bytes to be transferred during this DRQ assertion when executing a PACKET PIO data transfer 
command. 


byte count limit: The value placed in the Byte Count register by the host as input to a PACKET 
PIO data transfer command to specify the maximum byte count that may be transferred during a 
single DRQ assertion. 


CFA (CompactFlash™ Association): The CompactFlash™ Association which created the 
specification for compact flash memory that uses the ATA interface. 


check condition: For devices implementing the PACKET Command feature set, this indicates an 
error or exception condition has occurred. 


CHS (cylinder-head-sector): An obsolete method of addressing the data on the device by cylinder 
number, head number, and sector number. 
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3.1.22 


3.1.23 


3.1.24 


3.1.25 


3.1.26 


3.1.27 


3.1.28 


3.1.29 


3.1.30 


3.1.31 
3.1.32 


3.1.33 
3.1.34 


3.1.35 


3.1.36 


3.1.37 


3.1.38 


3.1.39 


3.1.40 


3.1.41 


3.1.42 
3.1.43 


code violation: In a serial interface implementation, a code violation is an error that occurs in the 
decoding of an encoded character. (See Volume 3, Clause 15) 


command aborted: Command completion with ABRT set to one in the Error register and ERR set 
to one in the Status register. 


command acceptance: A command is considered accepted whenever the currently selected 
device has the BSY bit cleared to zero in the Status register and the host writes to the Command 
register. An exception exists for the DEVICE RESET command (See Clause 6) In a serial 
implementation, command acceptance is a positive acknowledgment of a host to device register 
FIS. 


Command Block registers: Interface registers used for delivering commands to the device or 
posting status from the device. In a serial implementation, the command block registers are FIS 
payload fields. 


command completion: Command completion is the completion by the device of the action 
requested by the command or the termination of the command with an error, the placing of the 
appropriate error bits in the Error register, the placing of the appropriate status bits in the Status 
register, the clearing of both BSY and DRQ to zero, and Interrupt Pending. 


command packet: A data structure transmitted to the device during the execution of a PACKET 
command that includes the command and command parameters. 


command released: When a device supports overlap or queuing, a command is considered 
released when a bus release occurs before command completion. 


Control Block registers: In a parallel implementation, interface registers used for device control 
and to post alternate status. In a serial interface implementation, the logical field of a FIS 
corresponding to the Device Register bits of a parallel implementation. 


control character: In a serial interface implementation, an encoded character that represents a 
non-data byte (See Volume 3, Clause 15) 


CRC (Cyclical Redundancy Check): A means used to check the validity of certain data transfers. 


Cylinder High register: The name used for the LBA High register in previous ATA/ATAPI 
standards. 


Cylinder Low register: The name used for the LBA Mid register in previous ATA/ATAPI standards. 


data character: In a serial interface implementation, an encoded character that represents a data 
byte. (See Volume 3 Clause 15) 


data-in: The protocol that moves data from the device to the host. Such transfers are initiated by 
READ commands. 


data-out: The protocol that moves data from the host to the device. Such transfers are initiated by 
WRITE commands. 


Delayed LBA: Any sector for which the performance specified by the Streaming Performance 
Parameters log is not valid. 


device: A storage peripheral. Traditionally, a device on the interface has been a hard disk drive, 
but any form of storage device may be placed on the interface provided the device adheres to this 
standard. 


device selection: In a parallel implementation,a device is selected when the DEV bit of the Device 
register is equal to the device number assigned to the device by means of a Device 0/Device 1 
jumper or switch, or use of the CSEL signal. In a serial implementation the device ignores the DEV 
bit, the host adapter may use this bit to emulate device selection. 


disparity: The difference between the number of ones and the number of zeros in an encoded 
character. (See Volume 3, Clause 15) 


DMA (direct memory access) data transfer: A means of data transfer between device and host 
memory without host processor intervention. 


don’t care: A term to indicate that a value is irrelevant for the particular function described. 


driver: The active circuit inside a device or host that sources or sinks current to assert or negate a 
signal on the bus. 
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3.1.44 


3.1.45 


3.1.46 


3.1.47 


3.1.48 


3.1.49 


3.1.50 


3.1.51 
3.1.52 


3.1.53 
3.1.54 


3.1.55 


3.1.56 
3.1.57 


3.1.58 
3.1.59 


3.1.60 


3.1.61 


3.1.62 


3.1.63 


3.1.64 


3.1.65 


3.1.66 


3.1.67 


3.1.68 
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DRQ data block: A unit of data words transferred during a single assertion of DRQ when using PIO 
data transfer. 

elasticity buffer: In a serial interface implementation, a portion of the receiver where character 
slipping and/or character alignment is performed. 

encoded character: In a serial interface implementation, the output of the 8b/10b encoder. (See 
Volume 3, Clause 15) 

First party DMA access: A method by which a device accesses host memory. First party DMA 
differs from DMA in that the device sends a DMA Setup FIS to select host memory regions; whereas 
for DMA the host configures the DMA controller. 

FIS (Frame Information Structure): A data structure and is the payload of a frame and does not 
include the SOF primitive, CRC, and EOF primitive. 

frame: A unit of information exchanged between the host adapter and a device. A frame consists of 
an SOF primitive, a Frame Information Structure, a CRC calculated over the contents of the FIS, 
and an EOF primitive. 

FUA (Forced Unit Access): Forced Unit Access requires that user data be transferred to or from 
the device media before command completion even if caching is enabled. 


Geni DWORD Time: The time it takes to transmit a 40 bit encoded value at 1.5 Gb/Sec. 


host: The computer system executing the software BIOS and/or operating system device driver 
controlling the device and the adapter hardware for the ATA interface to the device. 


host adapter: The implementation of the host transport, link, and physical layers. 


Interrupt Pending: In a parallel implementation, an internal state of a device. In this state, the 
device asserts INTRQ if nIEN is cleared to zero and the device is selected (See Clause 9). Ina 
serial implementation, the Interrupt Pending state is an internal state of the host adapter. This state 
is entered by reception of a FIS with the | field set to one (See Volume 3, Clause 16) 

LBA (logical block address): The addressing of data on the device by the linear mapping of 
sectors. 


LFSR (Linear Feedback Shift Register): (See Volume 3 Clause 15) 


link: The link layer manages the phy layer to achieve the delivery and reception of frames. (See 
Volume 3, Clause 15) 


logical sector: A uniquely addressable set of 256 words (512 bytes). 


native max address: The highest address a device accepts in the factory default condition, that is, 
the highest address that is accepted by the SET MAX ADDRESS command. 


overlap: A protocol that allows devices that require extended command time to perform a bus 
release so that commands may be executed by the other device (if present) on the bus. 


packet delivered command: A command that is delivered to the device using the PACKET 
command via a command packet that contains the command and the command parameters. See 
also register delivered command. 


phy: Physical layer electronics, See Volume 3, Clause 14 


physical sector: A group of contiguous logical sectors that are read from or written to the device 
media in a single operation. 


PIO (programmed input/output) data transfer: PIO data transfers are performed by the host 
processor utilizing accesses to the Data register. 

primitive: In a serial interface implementation, a single DWORD of information that consists of a 
control character in byte O followed by three additional data characters in byte 1 through 3. 


queued: Command queuing allows the host to issue concurrent commands to the same device. 
Only commands included in the Overlapped feature set may be queued. In this standard, the queue 
contains all commands for which command acceptance has occurred but command completion has 
not occurred. 


read command: A command that causes the device to transfer data from the device to the host 
(e.g., READ SECTOR(S), READ DMA, etc.). 


register: A register may be a physical hardware register or a logical field. 


Page 7 


T13/1532D Volume 1 Revision 4b 


3.1.69 


3.1.70 


3.1.71 


3.1.72 


3.1.73 
3.1.74 


3.1.75 


3.1.76 


3.1.77 


3.1.78 


3.1.78 


3.1.79 


3.1.80 


3.1.81 


3.1.82 


3.1.83 


3.1.84 


register delivered command: A command that is delivered to the device by placing the command 
and all of the parameters for the command in the device Command Block registers. See also 
packet delivered command. 


register transfers: The host reading and writing any device register except the Data register. 
Register transfers are 8 bits wide. 


released: In a parallel interface implementation, indicates that a signal is not being driven. For 
drivers capable of assuming a high-impedance state, this means that the driver is in the high 
impedance state. For open-collector drivers, the driver is not asserted. 


sector: A uniquely addressable set of 256 words (512 bytes). 
Sector Number register:The LBA Low register in previous ATA/ATAPI standards. 


Shadow Command Block: In a serial interface implementation, a set of virtual fields in the host 
adapter that map the Command Block registers defined at the command layer to the fields within the 
FIS content. 


Shadow Control Block: In a serial interface implementation, a set of virtual fields in the host 
adapter that map the Control Block registers defined at the command layer to the fields within the 
FIS content. 


signature: A unique set of values placed in the Command Block registers by the device to allow the 
host to distinguish devices implementing the PACKET Command feature set from those devices not 
implementing the PACKET Command feature set. 


SMART (Self-Monitoring, Analysis, and Reporting Technology): for prediction of device degradation 
and/or faults. 


transport: The transport layer manages the lower layers (link and phy) as well as constructing and 
parsing FIS’s. See Volume 3, Clause 13 


Ultra DMA burst: An Ultra DMA burst is defined as the period from an assertion of DMACK- to the 
subsequent negation of DMACK- when an Ultra DMA transfer mode has been enabled by the host. 


unaligned write: A write command that does not start at the first logical sector of a physical sector 
or does not end at the last logical sector of a physical sector. 


unit attention condition: A state that a device implementing the PACKET Command feature set 
maintains while the device has asynchronous status information to report to the host. 


unrecoverable error: When the device sets either the ERR bit or the DF bit to one in the Status 
register at command completion. 


VS (vendor specific): Bits, bytes, fields, and code values that are reserved for vendor specific 
purposes. These bits, bytes, fields, and code values are not described in this standard, and may 
vary among vendors. This term is also applied to levels of functionality whose definition is left to the 
vendor. 

NOTE - Industry practice could result in conversion of a Vendor Specific bit, byte, field, or code 
value into a defined standard value in a future standard. 


write command: A command that causes the device to transfer data from the host to the device 
(e.g., WRITE SECTOR(S), WRITE DMA, etc.). 


WWN (world wide name): A 64-bit worldwide unique name based upon a company’s IEEE 
identifier. (See IDENTIFY DEVICE Words (108:111) in Volume 1 Clause 6). 


3.2 Conventions 


Lowercase is used for words having the normal English meaning. Certain words and terms used in this 
standard have a specific meaning beyond the normal English meaning. These words and terms are defined 
either in Clause 3 or in the text where they first appear. 


The names of abbreviations, commands, fields, and acronyms used as signal names are in all uppercase 
(e.g., IDENTIFY DEVICE). Fields containing only one bit are usually referred to as the "name" bit instead of 
the "name" field. (See 3.2.6 for the naming convention used for naming bits.) 
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device registers begin with a capital letter (e.g., LBA Mid register). 


ssion “word n” or “bit n” shall be interpreted as indicating the content of word n or bit n. 


3.2.1 Precedence 


If there is a conflict between text, figures, and tables, the precedence shall be tables, figures, then text. 


3.2.2 Lists 


Ordered lists, those lists describing a sequence, are of the form: 


3.2.3. Keywords 


Several keywords are used to differentiate between different levels of requirements and optionality. 


3.2.3.1 expected: A keyword used to describe the behavior of the hardware or software in the design 


models assumed by this standard. Other hardware and software design models may also be 
implemented. 


3.2.3.2 mandatory: A keyword indicating items to be implemented as defined by this standard. 


3.2.3.3 may: A keyword that indicates flexibility of choice with no implied preference. 


3.2.3.4 obsolete: A keyword indicating that the designated bits, bytes, words, fields, and code values that 


may have been defined in previous standards are not defined in this standard and shall not be 
reclaimed for other uses in future standards. However, some degree of functionality may be 
required for items designated as “obsolete” to provide for backward compatibility. 


Obsolete commands should not be used by the host. Commands defined as obsolete may be 
command aborted by devices conforming to this standard. However, if a device does not 
command abort an obsolete command, the minimum that is required by the device in response to 
the command is command completion. 


3.2.3.5 optional: A keyword that describes features that are not required by this standard. However, if any 


optional feature defined by the standard is implemented, the feature shall be implemented in the 
way defined by the standard. 


3.2.3.6 prohibited: A keyword indicating that an item shall not be implemented by an implementation. 


3.2.3.7 reserved: A keyword indicating reserved bits, bytes, words, fields, and code values that are set aside 


for future standardization. Their use and interpretation may be specified by future extensions to 
this or other standards. A reserved bit, byte, word, or field shall be cleared to zero, or in 
accordance with a future extension to this standard. The recipient shall not check reserved bits, 
bytes, words, or fields. Receipt of reserved code values in defined fields shall be treated as a 
command parameter error and reported by returning command aborted. 
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3.2.3.8 retired: A keyword indicating that the designated bits, bytes, words, fields, and code values that had 
been defined in previous standards are not defined in this standard and may be reclaimed for other 
uses in future standards. If retired bits, bytes, words, fields, or code values are used before they 
are reclaimed, they shall have the meaning or functionality as described in previous standards. 


3.2.3.9 shall: A keyword indicating a mandatory requirement. Designers are required to implement all such 
mandatory requirements to ensure interoperability with other products that conform to this 
standard. 


3.2.3.10 should: A keyword indicating flexibility of choice with a strongly preferred alternative. Equivalent to 
the phrase “it is recommended”. 


3.2.4 Numbering 


Numbers that are not immediately followed by a lowercase "b" or "h" are decimal values. Numbers that are 
immediately followed by a lowercase "b" (e.g., 01b) are binary values. Numbers that are immediately 
followed by a lowercase "h" (e.g., 3Ah) are hexadecimal values. 


3.2.5 Signal conventions 
Signal names are shown in all uppercase letters. 


All signals are either high active or low active signals. A dash character ( - ) at the end of a signal name 
indicates the signal is a low active signal. A low active signal is true when the signal is below Vj,, and is false 
when the signal is above Vi. No dash at the end of a signal name indicates the signal is a high active 
signal. A high active signal is true when the signal is above Viy, and is false when the signal is below V. 


Asserted means that the signal is driven by an active circuit to the true state. Negated means that the signal 
is driven by an active circuit to the false state. Released means that the signal is not actively driven to any 
state (See Clause 7). Some signals have bias circuitry that pull the signal to either a true state or false state 
when no signal driver is actively asserting or negating the signal. 


Control signals that may be used for more than one mutually exclusive functions are identified with their 
function names separated by a colon (e.g., DIOW-:STOP). 


SIGNAL(n:m) denotes a set of signals, for example, DD(15:0). 

3.2.6 Bit conventions 

Bit names are shown in all uppercase letters except where a lowercase n precedes a bit name. If there is no 
preceding n, then when BIT is set to one the meaning of the bit is true, and when BIT is cleared to zero the 


meaning of the bit is false. If there is a preceding n, then when nBIT is cleared to zero the meaning of the bit 
is true and when nBIT is set to one the meaning of the bit is false. 


True False 
TEST | | 
Bit setting=1 $= ———______________ 
Bit setting=0 / \ 
True False 
nTEST 
Bit setting=0 | | 


Bit setting=1 / \ 


Bit (n:m) denotes a set of bits, for example, bits (7:0). 
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3.2.7 State diagram conventions 


State diagrams shall be as shown in Figure 2. 


State designator: State_name State designator: State_name 
Entry condition Transition condition Exit condition 
—tTransition label Transition label Transition label ——» State_name 
Transition action Transition action Transition action 


Transition condition 
Transition label 


Transition action 


_ 


State re-entry 


| BSY | DRQ | REL 


SERV C/D V/O INTRQ 


Figure 2 - State diagram convention 


Each state is identified by a state designator and a state name. The state designator is unique among all 
states in all state diagrams in this document. The state designator consists of a set of letters that are 
capitalized in the title of the figure containing the state diagram followed by a unique number. The state 
name is a brief description of the primary action taken during the state, and the same state name may 
appear in other state diagrams. If the same primary function occurs in other states in the same state 
diagram, they are designated with a unique letter at the end of the name. Additional actions may be taken 
while in a state and these actions are described in the state description text. 


In device command protocol state diagrams, the state of bits and signals that change state during the 
execution of this state diagram are shown under the state designator:state_name, and a table is included 
that shows the state of all bits and signals throughout the state diagram as follows: 


v = bit value changes. 
1 = bit set to one. 

0 = bit cleared to zero. 
X = bit is don’t care. 

V = signal changes. 

A = signal is asserted. 
N = signal is negated. 
R = signal is released. 
X = signal is don’t care. 


Each transition is identified by a transition label and a transition condition. The transition label consists of the 
state designator of the state from which the transition is being made followed by the state designator of the 
state to which the transition is being made. In some cases, the transition to enter or exit a state diagram may 
come from or go to a number of state diagrams, depending on the command being executed. In this case, 
the state designator is labeled xx. The transition condition is a brief description of the event or condition that 
causes the transition to occur and may include a transition action, indicated in italics, that is taken when the 
transition occurs. This action is described fully in the transition description text. 


Upon entry to a state, all actions to be executed in that state are executed. If a state is re-entered from itself, 
all actions to be executed in the state are executed again. 
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Transitions from state to state shall be instantaneous. 
3.2.8 Timing conventions 


Certain symbols are used in the timing diagrams. These symbols and their respective definitions are listed 
below. 


/ or ‘ - signal transition (asserted or negated) 


( or ) - data transition (asserted or negated) 


= CD oe - data valid 


XXXX - undefined but not necessarily released 


- asserted, negated or released 


- released 
sgestecccreeccscaseoagg - the “other” condition if a signal is shown with no change 


All signals are shown with the asserted condition facing to the top of the page. The negated condition is 
shown towards the bottom of the page relative to the asserted condition. 


The interface uses a mixture of negative and positive signals for control and data. The terms asserted and 
negated are used for consistency and are independent of electrical characteristics. 


In all timing diagrams, the lower line indicates negated, and the upper line indicates asserted. The following 
illustrates the representation of a signal named TEST going from negated to asserted and back to negated, 
based on the polarity of the signal. 


Assert Negate 
TEST | | 
> Vin —————— as. 
Mig ge 
Assert Negate 
TEST- | 
< Vit | 


> Vin a EEE 
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3.2.9 Byte ordering for data transfers 


Data is transferred in blocks using either PIO or DMA protocols. PIO data transfers occur when the BSY bit is 
cleared to zero and the DRQ bit is set to one. These transfers are usually 16-bit but CFA devices may 
implement 8-bit PIO transfers. Data is transferred in blocks of one or more bytes known as a DRQ block. 
DMA data transfers occur when the host asserts DMACK- in response to the device asserting DMARQ. 
DMA transfers are always 16-bit. Each assertion of DMACK- by the host defines a DMA data burst. A DMA 
data burst is two or more bytes. 


Assuming a DRQ block or a DMA burst of data contains "n" bytes of information, the bytes are labeled 
Byte(0) through Byte(n-1), where Byte(0) is first byte of the block, and Byte(n-1) is the last byte of the block. 
Table 2 shows the order the bytes shall be presented in when such a block of data is transferred on the 
interface using 16-bit PIO and DMA transfers. Table 3 shows the order the bytes shall be presented in when 
such a block or burst of data is transferred on the interface using 8-bit PIO. 


Table 2 - Byte order 


DD | DD | DD } DD | DD | DD es a 
15 | 14 | 13 | 12 | 11 | 10 


| Firsttransfer | Byte (1) Byte (0) 


Second transfer 
Last transfer 


Table 3 - Byte order 


Ce abd 


| Firsttransfer | Byte (0) 


Byte (1) 


NOTE -— The above description is for data on the interface. Host systems and/or host adapters may cause 
the order of data as seen in the memory of the host to be different. 


Some parameters are defined as a string of ASCII characters. ASCII data fields shall contain only code 
values 20h through 7Eh. For the string “Copyright”, the character “C” is the first byte, the character “o” is the 
second byte, etc. When such fields are transferred, the order of transmission is: 


the 1" character (“C”) is on DD(15:8) of the first word, 
the 2" “ character (“o”) is on DD(7:0) of the first word, 

the 3" character (“p”) is on DD(15:8) of the second word, 
the 4" character (“y”) is on DD(7:0) of the second word, 
the 5" character (“r’) is on DD(15:8) of the third word, 
the 6" character (“i”) is on DD(7:0) of the third word, 

the t character (“g”) is on DD(15:8) of the fourth word, 
the 8" character (“h”) is on DD(7:0) of the fourth word, 
the 9" character (‘t’) is on DD(15:8) of the fifth word, 

the 10" character (“space”) is on DD(7:0) of the fifth word, 
etc. 


Word (n:m) denotes a set of words, for example, words (103:100). 
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3.2.10 Byte, word and DWORD Relationships 


Figure 3 illustrates the relationship between bytes, words and DWORDs for serial interface implementations. 


7 6 5 4 3 2 1 ~0 


Byte 


Byte 1 Byte 0 
332222 2 2 22 22i14d31d1d1d12312d312d312@91é«821 
109 8 765 432109 8 765 43 2109 8 765 43 2 1 «(0 
DWO 
RD 
Word 1 Word 0 
Byte 3 Byte 2 Byte 1 Byte 0 


Figure 3 - Byte, word and DWORD relationships 
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4 General operational requirements 


4.1 Command delivery 


Commands may be delivered in two forms. For devices that do not implement the PACKET Command 
feature set, all commands and command parameters are delivered by writing the device Command Block 
registers. Such commands are defined as register delivered commands. 


Devices that implement the PACKET Command feature set use packet delivered commands as well as 
some register delivered commands. 


All register delivered commands and the PACKET command are described in Clause 6. 


NOTE — The content of command packets delivered during execution of the PACKET command are not 
described in this standard. See Clause 1 for standards and specifications that define command packet 
content. 


4.2 Register delivered data transfer command sector addressing 


For register delivered data transfer commands all addressing of data sectors recorded on the device's media 
is by a logical sector address. There is no implied relationship between logical sector addresses and the 
actual physical location of the data sector on the media. All devices shall support LBA translation. 


In standards ATA/ATAPI-5 and earlier, a CHS translation was defined. This translation is obsolete but if 
implemented it shall be implemented as defined in ATA/ATAPI-5. 


4.2.1 Definitions and value ranges of IDENTIFY DEVICE data words 
(Also See Clause 6.17) 


1) Words (61:60) shall contain the value one greater than the total number of user-addressable 
sectors in 28-bit addressing and shall not exceed OFFFFFFFh. The content of words (61:60) 
shall be greater than or equal to one and less than or equal to 268,435,455. 

2) Words (103:100) shall contain the value one greater than the total number of user-addressable 
sectors in 48-bit addressing and shall not exceed OOOOFFFFFFFFFFFFh. 

3) The contents of words (61:60) and (103:100) may be affected by the host issuing a SET MAX 
ADDRESS or SET MAX ADDRESS EXT command. 

4) The contents of words (61:60) and (103:100) shall not be used to determine if 48-bit addressing 
is supported. IDENTIFY DEVICE bit 10 word 83 indicates support for 48-bit addressing. 


4.2.2 Addressing constraints and error reporting 
Devices shall set IDNF to one or ABRT to one in the Error register and ERR to one in the Status register in 
response to any command where the requested LBA number is greater than or equal to the content of words 


(61:60) for a 28-bit addressing command or greater or equal to the contents of words (103:100) for a 48-bit 
addressing command. 


4.3 General feature set 
The General feature set defines the common commands implemented by devices. 
4.3.1 General feature set for devices not implementing the PACKET command feature set 


The following General feature set commands are mandatory for all devices that are capable of both reading 
and writing their media and do not implement the PACKET command feature set: 


— EXECUTE DEVICE DIAGNOSTIC 
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— FLUSH CACHE 
— IDENTIFY DEVICE 

— READ DMA 

— READ MULTIPLE 

— READ SECTOR(S) 

— READ VERIFY SECTOR(S) 
— SET FEATURES 

— SET MULTIPLE MODE 

— WRITE DMA 

— WRITE MULTIPLE 

— WRITE SECTOR(S) 


The following General feature set commands are mandatory for all devices that are capable of only reading 
their media and do not implement the PACKET command feature set: 


— EXECUTE DEVICE DIAGNOSTIC 
— IDENTIFY DEVICE 

— READ DMA 

— READ MULTIPLE 

— READ SECTOR(S) 

— READ VERIFY SECTOR(S) 

— SET FEATURES 

— SET MULTIPLE MODE 


The following General feature set commands are optional for devices not implementing the PACKET 
command feature set: 


— DOWNLOAD MICROCODE 
— NOP 

— READ BUFFER 

— WRITE BUFFER 


The following General feature set command is prohibited for use by devices not implementing the PACKET 
command feature set: 


— DEVICE RESET 
The following resets are mandatory for devices not implementing the PACKET command feature set: 


— Power-on reset: Executed at power-on, the device may execute a series of diagnostics and shall 
set default values (See Clauses 11, 17). 

— Hardware reset: Executed in response to the assertion of the RESET- signal the device may 
execute a series of diagnostics and shall set default values (See Clauses 11, 17). 

— Software reset: Executed in response to the setting of the SRST bit in the Device Control 
register the device resets the interface circuitry (See Clauses 11, 17). 


4.3.2 General feature set for devices implementing the PACKET command feature set 


The following General feature set commands are mandatory for all devices implementing the PACKET 
command feature set: 


— EXECUTE DEVICE DIAGNOSTIC 
— IDENTIFY DEVICE 

— NOP 

— READ SECTOR(S) 
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— SET FEATURES 


The following General feature set commands are optional for all devices implementing the PACKET 
command feature set: 


— FLUSH CACHE 


The following General command set commands are prohibited for use by devices implementing the PACKET 
command feature set. These functions are supported by Packet commands. 


— DOWNLOAD MICROCODE 
— READ BUFFER 

— READ DMA 

— READ MULTIPLE 

— READ VERIFY 

— SET MULTIPLE MODE 

— WRITE BUFFER 

— WRITE DMA 

— WRITE MULTIPLE 

— WRITE SECTOR(S) 


The following resets are mandatory for devices implementing the PACKET command feature set: 


— Power-on reset: Executed at power-on, the device may execute a series of diagnostics and shall 
set default values (See Clause 11). 

— Hardware reset: Executed in response to the assertion of the RESET- signal the device may 
execute a series of and shall set default values (See Clause 11). 

— Software reset: Executed in response to the setting of the SRST bit in the Device Control 
register the device resets the interface circuitry (See Clause 11). 

— DEVICE RESET: Executed in response to the DEVICE RESET command the device resets the 
interface circuitry (See 6.11). 


4.4 PACKET Command feature set 


The optional PACKET Command feature set provides for devices that require command parameters that are 
too extensive to be expressed in the Command Block registers. Devices implementing the PACKET 
Command feature set exhibit responses different from those exhibited by devices not implementing this 
feature set. 


The commands unique to the PACKET Command feature set are: 


— PACKET 
— DEVICE RESET 
— IDENTIFY PACKET DEVICE 


4.4.1 Identification of PACKET Command feature set devices 


When executing a power-on, hardware, DEVICE RESET, or software reset, a device implementing the 
PACKET Command feature set shall perform the same reset protocol as other devices, but leaves the 
registers with a signature unique to PACKET Command feature set devices (See 5.15). 


In addition, the IDENTIFY DEVICE command shall not be executed but shall be command aborted and shall 
return a signature unique to devices implementing the PACKET Command feature set. The IDENTIFY 
PACKET DEVICE command is used by the host to get identifying parameter information for a device 
implementing the PACKET Command feature set (See 6.17.5.2 and 6.18). 
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4.4.2 PACKET Command feature set resets 


Devices implementing the PACKET Command feature set respond to power-on, hardware, and software 
resets as any other device except for the resulting contents in the device registers as described above. 
However, software reset should not be issued while a PACKET command is in progress. PACKET 
commands used by some devices do not terminate if a software reset is issued. 


The DEVICE RESET command is provided to allow the device to be reset without affecting the other device 
on the bus. 


4.4.3 The PACKET command 


The PACKET command allows a host to send a command to the device via a command packet. The 
command packet contains the command and command parameters that the device is to execute (See 
Clause 1). 


Upon receipt of the PACKET command the device sets BSY to one and prepares to receive the command 
packet. When ready, the device sets DRQ to one and clears BSY to zero. The command packet is then 
transferred to the device by PIO transfer. When the last word of the command packet is transferred, the 
device sets BSY to one, and clears DRQ to zero (See 6.25 and Clause 10). 


4.5 Power Management feature set 


A device shall implement power management. A device implementing the PACKET Command feature set 
may implement the power management as defined by the PACKET command set implemented by the 
device. Otherwise, the device shall implement the Power Management feature set as described in this 
standard. 


The Power Management feature set permits a host to modify the behavior of a device in a manner that 
reduces the power required to operate. The Power Management feature set provides a set of commands 
and a timer that enable a device to implement low power consumption modes. A register delivered command 
device that implements the Power Management feature set shall implement the following minimum set of 
functions: See also 4.6 and 4.12. 


— A Standby timer 

— CHECK POWER MODE command 
— IDLE command 

— IDLE IMMEDIATE command 

— SLEEP command 

— STANDBY command 

— STANDBY IMMEDIATE command 


A device that implements the PACKET Command feature set and implements the Power Management 
feature set shall implement the following minimum set of functions: 


— CHECK POWER MODE command 
— IDLE IMMEDIATE command 

— SLEEP command 

— STANDBY IMMEDIATE command 


4.5.1 Power management commands 
The CHECK POWER MODE command allows a host to determine if a device is currently in, going to or 


leaving Standby or Idle mode. The CHECK POWER MODE command shall not change the power mode or 
affect the operation of the Standby timer. 
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The IDLE and IDLE IMMEDIATE commands move a device to Idle mode immediately from the Active or 
Standby modes. The IDLE command also sets the Standby timer count and enables or disables the Standby 
timer. 


The STANDBY and STANDBY IMMEDIATE commands move a device to Standby mode immediately from 
the Active or Idle modes. The STANDBY command also sets the Standby timer count and enables or 
disables the Standby timer. 

The SLEEP command moves a device to Sleep mode. The device's interface becomes inactive at command 
completion of the SLEEP command. A hardware or software reset or DEVICE RESET command is required 
to move a device out of Sleep mode. 

4.5.2 Standby timer 

The Standby timer provides a method for the device to automatically enter Standby mode from either Active 
or Idle mode following a host programmed period of inactivity. If the Standby timer is enabled and if the 
device is in the Active or Idle mode, the device waits for the specified time period and if no command is 
received, the device automatically enters the Standby mode. 

If the Standby timer is disabled, the device may automatically enter Standby mode. 


4.5.3 Power modes 


Figure 4 shows the set of mode transitions that shall be implemented. 
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PMO: Active 


Power-up with Power-up in Standby 
feature not implemented or not enabled 


SLEEP command 
PMO:PM3 


PM1: Idle 
STANDBY or STANDBY 
IMMEDIATE command, IDLE or IDLE 
vendor specific IMMEDIATE 
implementation, or command, or 


Power-up with Standby timer expiration if 
Power-up in vendor specific 


PM2: Standby 


Standby |< PMO0:PM2 implementation 
inp mentee Media access required PMO:PM1 


and enabled 


¢ ———————— A j 
PM2:PMO Media access required 


reset PM1:PMO 
Cee STANDBY or STANDBY 
IMMEDIATE command, vendor 
specific implementation, or 
Standby timer expiration 
PM1:PM2 


IDLE or IDLE IMMEDIATE 
command 


PM2:PM1 


PM3: Sleep 
SLEEP command SLEEP command 


PM2:PM3 PM1:PM3 


Figure 4 - Power management state diagram 


PMO: Active: This mode shall be entered when the device receives a media access command while in 
Idle or Standby mode. This mode shall also be entered when the device is powered-up with the Power-Up In 
Standby feature not implemented or not enabled (See 4.12). 


In Active mode the device is capable of responding to commands. During the execution of a media access 
command a device shall be in Active mode. Power consumption is greatest in this mode. 


Transition PMO:PMO: When hardware reset, software reset, or DEVICE RESET command is received, the 
device shall make a transition to the PMO: Active mode when the reset protocol is completed. 


Transition PM0O:PM1: When an IDLE or IDLE IMMEDIATE command is received or when a vendor specific 


implementation determines a transition is required, then the device shall make a transition to the PM1:Idle 
mode. 
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Transition PM0O:PM2: When a STANDBY or STANDBY IMMEDIATE command is received, the Standby 
timer expires, or a vendor specific implementation determines a transition is required, then the device shall 
make a transition to the PM2:Standby mode. 


Transition PM0:PM3: When a SLEEP command is received, the device shall make a transition to the 
PM3:Sleep mode. 


PM1: Idle: This mode shall be entered when the device receives an IDLE or IDLE IMMEDIATE command. 
Some devices may perform vendor specific internal power management and make a transition to the Idle 
mode without host intervention. 


In Idle mode the device is capable of responding to commands but the device may take longer to complete 
commands than when in the Active mode. Power consumption may be reduced from that of Active mode. 


Transition PM1:PM0: When a media access is required, the device shall make a transition to the 
PMO:Active mode. 


Transition PM1:PM1: When hardware reset, software reset, or DEVICE RESET command is received, the 
device shall make a transition to the PM1:Idle mode when the reset protocol is completed. 


Transition PM1:PM2: When a STANDBY or STANDBY IMMEDIATE command is received, the Standby 
timer expires, or a vendor specific implementation determines a transition is required, then the device shall 
make a transition to the PM2:Standby mode. 


Transition PM1:PM3: When a SLEEP command is received, the device shall make a transition to the 
PM3:Sleep mode. 


PM2: Standby: This mode shall be entered when the device receives a STANDBY command, a 
STANDBY IMMEDIATE command, or the Standby timer expires. Some devices may perform vendor specific 
internal power management and make a transition to the Standby mode without host intervention. This mode 
shall also be entered when the device is powered-up with the Power-Up In Standby feature implemented and 
enabled. 


In Standby mode the device is capable of responding to commands but the device may take longer to 
complete commands than in the Idle mode. The time to respond could be as long as 30 s. Power 
consumption may be reduced from that of Idle mode. 


Transition PM2:PM0: When a media access is required, the device shall make a transition to the 
PMO:Active mode. 


Transition PM2:PM1: When an IDLE or IDLE IMMEDIATE command is received, or a vendor specific 
implementation determines a transition is required, then the device shall make a transition to the PM1:Idle 
mode. 


Transition PM2:PM2: When hardware reset, software reset, or DEVICE RESET command is received, the 
device shall make a transition to the PM2:Standby mode when the reset protocol is completed. 


Transition PM2:PM3: When a SLEEP command is received, the device shall make a transition to the 
PM3:Sleep mode. 


PM3: Sleep: This mode shall be entered when the device receives a SLEEP command. 

In Sleep mode the device requires a hardware or software reset or a DEVICE RESET command to be 
activated. The time to respond could be as long as 30 s. Sleep mode provides the lowest power consumption 
of any mode. 


In Sleep mode, the device's interface is not active. The content of the Status register is invalid in this mode. 
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Transition PM3:PM2:, When hardware reset, software reset, or DEVICE RESET command is received the 
device shall make a transition to the PM2:Standby mode. 


4.6 Advanced Power Management feature set 


The Advanced Power Management feature set is an optional feature set that allows the host to select a 
power management level. The power management level is specified using a scale from the lowest power 
consumption setting of 01h to the maximum performance level of FEh. Device performance may increase 
with increasing power management levels. Device power consumption may increase with increasing power 
management levels. A device may implement one power management method for two or more contiguous 
power management levels. For example, a device may implement one power management method from 
level 80h to AOh and a higher performance, higher power consumption method from level A1h to FEh. 
Advanced power management levels 80h and higher do not permit the device to spin down to save power. 


The Advanced Power Management feature set uses the following functions: 


— ASET FEATURES subcommand to enable Advanced Power Management 
— ASET FEATURES subcommand to disable Advanced Power Management 


Advanced Power Management is independent of the Standby timer setting. If both Advanced Power 
Management and the Standby timer are set, the device will go to the Standby state when the timer times out 
or the device’s Advanced Power Management algorithm indicates that the Standby state should be entered. 


The IDENTIFY DEVICE command indicates that Advanced Power Management is supported, whether 
Advanced Power Management is enabled, and the current advanced power management level if Advanced 
Power Management is enabled. 


4.7 Security Mode feature set 


The optional Security Mode feature set is a password system that restricts access to user data stored on a 
device. The system has two passwords, User and Master, and two security levels, High and Maximum. The 
security system is enabled by sending a user password to the device with the SECURITY SET PASSWORD 
command. When the security system is enabled, access to user data on the device is denied after a power 
cycle until the User password is sent to the device with the SECURITY UNLOCK command. 


A Master password may be set in addition to the User password. The purpose of the Master password is to 
allow an administrator to establish a password that is kept secret from the user, and which may be used to 
unlock the device if the User password is lost. Setting the Master password does not enable the password 
system. 


The security level is set to High or Maximum with the SECURITY SET PASSWORD command. The security 
level determines device behavior when the Master password is used to unlock the device. When the security 
level is set to High the device requires the SECURITY UNLOCK command and the Master password to 
unlock. When the security level is set to Maximum the device requires a SECURITY ERASE PREPARE 
command and a SECURITY ERASE UNIT command with the masterpassword to unlock. Execution of the 
SECURITY ERASE UNIT command erases all user data on the device. 


The SECURITY FREEZE LOCK command prevents changes to passwords until a following power cycle. 
The purpose of the SECURITY FREEZE LOCK command is to prevent password setting attacks on the 
security system. 


A device that implements the Security Mode feature set shall implement the following minimum set of 
commands: 


— SECURITY SET PASSWORD 
— SECURITY UNLOCK 

— SECURITY ERASE PREPARE 
— SECURITY ERASE UNIT 
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— SECURITY FREEZE LOCK 
— SECURITY DISABLE PASSWORD 


Support of the Security Mode feature set is indicated in IDENTIFY DEVICE data word 82 and data word 128. 
4.7.1 Security mode initial setting 


When the device is shipped by the manufacturer, the state of the Security Mode feature shall be disabled. 
The initial Master password value is not defined by this standard. 


If the Master Password Revision Code feature is supported, the Master Password Revision Code shall be set 
to FFFEh by the manufacturer. 


4.7.2 User password lost 


If the User password sent to the device with the SECURITY UNLOCK command does not match the user 
password previously set with the SECURITY SET PASSWORD command, the device shall not allow the 
user to access data. 


If the Security Level was set to High during the last SECURITY SET PASSWORD command, the device 
shall unlock if the Master password is received. 


If the Security Level was set to Maximum during the last SECURITY SET PASSWORD command, the device 
shall not unlock if the Master password is received. The SECURITY ERASE UNIT command shall erase all 
user data and unlock the device if the Master password matches the last Master password previously set 
with the SECURITY SET PASSWORD command. 


4.7.3 Attempt limit for SECURITY UNLOCK command 

The device shall have an attempt limit counter. The purpose of this counter is to defeat repeated trial attacks. 
After each failed User or Master password SECURITY UNLOCK command, the counter is decremented. 
When the counter value reaches zero the EXPIRE bit (bit 4) of IDENTIFY DEVICE data word 128 is set to 
one, and the SECURITY UNLOCK and SECURITY UNIT ERASE commands are command aborted until the 
device is powered off or hardware reset. The EXPIRE bit shall be cleared to zero after power-on or hardware 
reset. The counter shall be set to five after a power-on or hardware reset. 

4.7.4 Security mode states 


Figure 5 decribes security mode states and state transitions. 
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Figure 5 - Security mode state diagram 


SECO: Powered down/Security disabled: 


This mode shall be entered when the device is 


powered-down with the Security Mode feature set disabled. 


Transition SECO:SEC1: When the device is powered-up, the device shall make a transition to the SEC1: 


Security disabled/not Frozen state. 


SEC1: Security disabled/not Frozen: This mode shall be entered when the device is powered-up 
or a hardware reset is received with the Security Mode feature set disabled or when the Security Mode 
feature set is disabled by a SECURITY DISABLE PASSWORD or SECURITY ERASE UNIT command. 
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In this state, the device is capable of responding to all commands (See Table 4 Unlocked column). 


Transition SEC1:SECO: When the device is powered-down, the device shall make a transition to the SECO: 
Powered down/Security disabled state. 


Transition SEC1:SEC1: When the device receives a hardware reset, the device shall make a transition to 
the SEC1: Security disabled/not Frozen state. 


Transition SEC1:SEC2: When a SECURITY FREEZE LOCK command is received, the device shall make a 
transition to the SEC2: Security disabled/Frozen state. 


Transition SEC1:SEC5: When a SECURITY SET PASSWORD command is received, the device shall 
make a transition to the SEC5: Unlocked/not frozen state 


SEC2: Security disabled/Frozen: This mode shall be entered when the device receives a 
SECURITY FREEZE LOCK command while in Security disabled/not Frozen state. 


In this state, the device is capable of responding to all commands except those indicated in Table 4 Frozen 
column. 


Transition SEC2:SECO: When the device is powered-down, the device shall make a transition to the SECO: 
Powered down/Security disabled state. 


Transition SEC2:SEC1: When the device receives a hardware reset, the device shall make a transition to 
the SEC1: Security disabled/not Frozen state. 


SEC3: Powered down/Security enabled: This mode shall be entered when the device is 
powered-down with the Security Mode feature set enabled. 


Transition SEC3:SEC4: When the device is powered-up, the device shall make a transition to the SEC4: 
Security enabled/locked state. 


SEC4: Security enabled/Locked: This mode shall be entered when the device is powered-up or a 
hardware reset is received with the Security Mode feature set enabled. 


In this state, the device shall only respond to commands that do not access data in the user data area of the 
media (See Table 4 Locked column). 


Transition SEC4:SEC3: When the device is powered-down, the device shall make a transition to the SEC3: 
Powered down/Security enabled state. 


Transition SEC4:SEC4: When the device receives a hardware reset, the device shall make a transition to 
the SEC4: Security enabled/locked state. 


Transition SEC4:SEC5: When a valid SECURITY UNLOCK command is received, the device shall make a 
transition to the SEC5: Unlocked/not Frozen state. 


Transition SEC4:SEC1: When a SECURITY ERASE PREPARE command is received and is followed by a 


SECURITY ERASE UNIT command, the device shall make a transition to the SEC1: Security disabled/not 
Frozen state. 


SEC5: Unlocked/not Frozen: This mode shall be entered when the device receives a SECURITY 
SET PASSWORD command to enable the lock or a SECURITY UNLOCK command. 


In this state, the device shall respond to all commands (See Table 4 Unlocked column). 
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Transition SEC5a:SEC1: When a valid SECURITY DISABLE PASSWORD command is received, the 
device shall make a transition to the SEC1: Security disabled/not Frozen state. 


Transition SEC5b:SEC1: When a SECURITY ERASE PREPARE command is received and is followed by a 
SECURITY ERASE UNIT command, the device shall make a transition to the SEC1: Security disabled/not 
Frozen state. 


Transition SEC5:SEC6: When a SECURITY FREEZE LOCK command is received, the device shall make a 
transition to the SEC6: Unlocked/Frozen state. 


Transition SEC5:SEC3: When the device is powered-down, the device shall make a transition to the SEC3: 
Powered down/Security enabled state. 


Transition SEC5:SEC4: When the device receives a hardware reset, the device shall make a transition to 
the SEC4: Security enabled/Locked state. 


SEC6: Unlocked/ Frozen: This mode shall be entered when the device receives a SECURITY 
FREEZE LOCK command while in Unlocked/Locked state. 


In this state, the device is capable of responding to all commands except those indicated in Table 4 Frozen 
column. 


Transition SEC6:SEC3: When the device is powered-down, the device shall make a transition to the SEC3: 
Powered down/Security enabled state. 


Transition SEC6:SEC4: When the device receives a hardware reset, the device shall make a transition to 
the SEC4: Security enabled/Locked state. 
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Table 4 - Security mode command actions 


Po Command | kocked | Unlocked | Frozen 
IDLE 


(continued) 
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Table 4 - Security mode command actions (continued) 
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Unlocked 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 


Frozen 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
Executable 
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4.8 SMART (Self-monitoring, analysis, and reporting technology) feature set 


The intent of self-monitoring, analysis, and reporting technology (the SMART feature set) is to protect user 
data and minimize the likelihood of unscheduled system downtime that may be caused by predictable 
degradation and/or fault of the device. By monitoring and storing critical performance and calibration 
parameters, SMART feature set devices attempt to predict the likelinood of near-term degradation or fault 
condition. Providing the host system the knowledge of a negative reliability condition allows the host system 
to warn the user of the impending risk of a data loss and advise the user of appropriate action. Support of 
this feature set is indicated in the IDENTIFY DEVICE data. 


Devices that implement the PACKET Command feature set shall not implement the SMART feature set as 
described in this standard. Devices that implement the PACKET Command feature set and SMART shall 
implement SMART as defined by the command packet set implemented by the device. This feature set is 
optional if the PACKET Command feature set is not supported. 


4.8.1 Device SMART data structure 

SMART feature set capability and status information for the device are stored in the device SMART data 
structure. The off-line data collection capability and status data stored herein may be useful to the host if the 
SMART EXECUTE OFF-LINE IMMEDIATE command is implemented (See 6.54.4). 

4.8.2 On-line data collection 

Collection of SMART data in an “on-line” mode shall have no impact on device performance. The SMART 
data that is collected or the methods by which data is collected in this mode may be different than those in 
the off-line data collection mode for any particular device and may vary from one device to another. 

4.8.3 Off-line data collection 

The device shall use off-line mode for data collection and self-test routines that have an impact on 
performance if the device is required to respond to commands from the host while performing that data 
collection. This impact on performance may vary from device to device. The data that is collected or the 
methods by which the data is collected in this mode may be different than those in the on-line data collection 
mode for any particular device and may vary from one device to another. 


4.8.4 Threshold exceeded condition 


This condition occurs when the device’s SMART reliability status indicates an impending degrading or fault 
condition. 


4.8.5 SMART feature set commands 


These commands use a single command code and are differentiated from one another by the value placed 
in the Features register (See 6.54). 


If the SMART feature set is implemented, the following commands shall be implemented. 


— SMART DISABLE OPERATIONS 

— SMART ENABLE/DISABLE AUTOSAVE 
— SMART ENABLE OPERATIONS 

— SMART RETURN STATUS 


If the SMART feature set is implemented, the following commands may be implemented. 
— SMART EXECUTE OFF-LINE IMMEDIATE 


— SMART READ DATA 
— SMART READ LOG 
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— SMART WRITE LOG 
— READ LOG EXT 
— WRITE LOG EXT 


4.8.6 SMART operation with power management modes 


When used with a host that has implemented the Power Management feature set, a SMART enabled device 
should automatically save the device accumulated SMART data upon receipt of an IDLE IMMEDIATE, 
STANDBY IMMEDIATE, or SLEEP command or upon return to an Active or Idle mode from a Standby mode 
(See 6.54.5). 


If a SMART feature set enabled device has been set to use the Standby timer, the device should 
automatically save the device accumulated SMART data prior to going from an Idle mode to the Standby 
mode or upon return to an Active or Idle mode from a Standby mode. 


A device shall not execute any routine to automatically save the device accumulated SMART data while the 
device is in a Standby or Sleep mode. 


4.8.7 SMART device error log reporting 


Logging of reported errors is an optional SMART feature. If error logging is supported by a device, it is 
indicated in byte 370 of the SMART READ DATA command response and bit 0 of word 84 of the IDENTIFY 
DEVICE response. If error logging is supported, the device shall provide information on the last five errors 
that the device reported as described in the SMART READ LOG command (See 6.54.6). The device may 
also provide additional vendor specific information on these reported errors. 


If error logging is supported, it shall not be disabled when SMART is disabled. Error log information shall be 
gathered when the device is powered-on except that logging of errors when in a reduced power mode is 
optional. If errors are logged when in a reduced power mode, the reduced power mode shall not change. 
Disabling SMART shall disable the delivering of error log information via the SMART READ LOG command. 


If a device receives a firmware modification, all error log data shall be discarded and the device error count 
for the life of the device shall be reset to zero. 


4.9 Host Protected Area feature set 


A reserved area for data storage outside the normal operating system file system is required for several 
specialized applications. Systems may wish to store configuration data or save memory to the device in a 
location that the operating systems cannot change. The optional Host Protected Area feature set allows a 
portion of the device to be reserved for such an area when the device is initially configured. A device that 
implements the Host Protected Area feature set shall implement the following minimum set of commands: 


— READ NATIVE MAX ADDRESS 
— SET MAX ADDRESS 


A device that implements the Host Protected Area feature set and supports the 48-bit Address feature set 
shall implement the following additional set of commands: 


— READ NATIVE MAX ADDRESS EXT 
— SET MAX ADDRESS EXT 


Devices supporting this feature set shall set bit 10 of word 82 to one in the data returned by the IDENTIFY 
DEVICE or IDENTIFY PACKET DEVICE command. 


In addition, a device supporting the Host Protected Area feature set may optionally include the security 


extensions. The Host Protected Area security commands use a single command code and are differentiated 
from one another by the value placed in the Features register. 
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— SET MAX SET PASSWORD 
— SET MAX LOCK 

— SET MAX FREEZE LOCK 

— SET MAX UNLOCK 


Devices supporting these extensions shall set bit 10 of word 82 and bit 8 of word 83 of the IDENTIFY 
DEVICE or IDENTIFY PACKET DEVICE data to one. 


The READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT command allows the host to 
determine the maximum native address space of the device even when a protected area has been allocated. 


The SET MAX ADDRESS or SET MAX ADDRESS EXT command allows the host to redefine the maximum 
address of the user accessible address space. That is, when the SET MAX ADDRESS or SET MAX 
ADDRESS EXT command is issued with a maximum address less than the native maximum address, the 
device reduces the user accessible address space to the maximum specified by the command, providing a 
protected area above that maximum address. The SET MAX ADDRESS or SET MAX ADDRESS EXT 
command shall be immediately preceded by a READ NATIVE MAX ADDRESS or READ NATIVE MAX 
ADDRESS EXT command. After the SET MAX ADDRESS or SET MAX ADDRESS EXT command has been 
issued, the device shall report only the reduced user address space in response to an IDENTIFY DEVICE 
command in words 60, 61, 100, 101, 102, and 103. Any read or write command to an address above the 
maximum address specified by the SET MAX ADDRESS or SET MAX ADDRESS EXT command shall 
cause command completion with the IDNF bit set to one and ERR set to one, or command aborted. A 
volatility bit in the Sector Count register allows the host to specify if the maximum address set is preserved 
across power-on or hardware reset cycles. On power-on or hardware reset the device maximum address 
returns to the last non-volatile address setting regardless of subsequent volatile SET MAX ADDRESS or 
SET MAX ADDRESS EXT commands. If the SET MAX ADDRESS or SET MAX ADDRESS EXT command 
is issued with a value that exceeds the native maximum address command aborted shall be returned. 


Typical use of these commands would be: 
On reset 


a) BIOS receives control after a system reset; 

b) BIOS issues a READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT 
command to find the max capacity of the device; 

c) BIOS issues a SET MAX ADDRESS or SET MAX ADDRESS EXT command to the values 
returned by READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT; 

d) BIOS reads configuration data from the highest area on the disk; 

e) BIOS issues a READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT 
command followed by a SET MAX ADDRESS or SET MAX ADDRESS EXT command to reset 
the device to the size of the file system. 


On save to disk 


a) BIOS receives control prior to shut down; 

b) BIOS issues a READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT 
command to find the max capacity of the device; 

c) BIOS issues a volatile SET MAX ADDRESS or SET MAX ADDRESS EXT command to the 
values returned by READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT; 

d) Memory is copied to the reserved area; 

e) Shut down completes; 

f) On power-on or hardware reset the device max address returns to the last non-volatile setting. 


These commands are intended for use only by system BIOS or other low-level boot time process. Using 
these commands outside BIOS controlled boot or shutdown may result in damage to file systems on the 
device. Devices should return command aborted if a subsequent non-volatile SET MAX ADDRESS or SET 
MAX ADDRESS EXT command is received after a power-on or hardware reset. 
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The SET MAX SET PASSWORD command allows the host to define the password to be used during the 
current power-on cycle. The password does not persist over a power cycle but does persist over a hardware 
or software reset. This password is not related to the password used for the Security Mode Feature set. 
When the password is set the device is in the Set_Max_Unlocked mode. 


The SET MAX LOCK command allows the host to disable the SET MAX commands (except SET MAX 
UNLOCK) until the next power cycle or the issuance and acceptance of the SET MAX UNLOCK command. 
When this command is accepted the device is in the Set_Max_Locked mode. 


The SET MAX UNLOCK command changes the device from the Set_Max_Locked mode to the 
Set_Max_Unlocked mode. 


The SET MAX FREEZE LOCK command allows the host to disable the SET MAX commands (including SET 
MAX UNLOCK) until the next power cycle. When this command is accepted the device is in the 
Set_Max_Frozen mode. 


4.9.1 BIOS determination of SET MAX security exension status 


When the device is locked bit 8 of word 86 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data 
shall be set to one. 


4.9.2 BIOS locking SET MAX 


To allow for multiple BIOSs to gain access to the protected area the host BIOS should only lock the 
protected area immediately prior to booting the operating system. 


Figure 6 is the SET MAX state diagram. 
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Figure 6 - SET MAX security state diagram 


SMO: Set_Max_Security_Inactive: This state shall be entered when the device is powered-on. 
When in this state, SET MAX security is disabled. 


Transition SM0a:SM0O: When a SET MAX ADDRESS command is received, the command shall be 
executed and the device shall make a transition to the SMO: Set_MAX_Security_Inactive state. 


Transition SMOb:SMO: When a SET MAX LOCK, SET MAX UNLOCK, or SET MAX FREEZE LOCK 
command is received, the device shall abort the command and make a transition to the SMO: 
Set_MAX_Security_Inactive state. 


Transition SM0:SM1: When a SET MAX SET PASSWORD command is received, the device shall make a 
transition to the SM1: Set_Max_Unlocked state. 


SM1: Set_Max_Unlocked: This state is entered when a SET MAX SET PASSWORD or a SET MAX 
UNLOCK command is received. 


When in this state, a SET MAX security password has been established and the SET MAX security is 
unlocked. Bit 8 of word 86 of the IDENTIFY DEVICE data shall be set to one. 


Transition SM1a:SM1: When a SET MAX ADDRESS command is received, the command shall be 
executed and the device shall make a transition to the SM1: Set_MAX_Unlocked state. 
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Transition SM1b:SM1: When a SET MAX SET PASSWORD is received, the password stored by the device 
shall be changed to the new value and the device shall make a transition to the SM1: Set_MAX_Unlocked 
state. 


Transition SM1ic:SM1: When a SET MAX UNLOCK command is received, the command shall not be 
executed and the device shall make a transition to the SM1: Set_MAX_Unlocked state. 


Transition SM1:SM2: When a SET MAX LOCK command is received, the device shall make a transition to 
the SM2: Set_Max_Locked state. 


Transition SM1:SM3: When a SET MAX FREEZE LOCK command is received, the device shall make a 
transition to the SM3: Set_Max_Frozen state. 


SM2: Set_Max_Locked: This state is entered when a SET MAX LOCK command is received. 


When in this state, a SET MAX security password has been established and the SET MAX security is locked. 
Bit 8 of word 86 of the IDENTIFY DEVICE data shall be set to one. 


Transition SM2a:SM2: When a SET MAX ADDRESS or SET MAX SET PASSWORD command is received, 
the command shall be aborted and the device shall make a transition to the SM2: Set_Max_Locked state. 


Transition SM2b:SM2: When a SET MAX LOCK command is received, the command shall be executed 
and the device shall make a transition to the SM2: Set_Max_Locked state. 


Transition SM2:SM1: When a SET MAX UNLOCK command is received, the device shall make a transition 
to the SM1: Set Max Unlocked state. 


Transition SM2:SM3: When a SET MAX FREEZE LOCK command is received, the device may make a 
transition to the SM3: Set_Max_Frozen state. Hosts should not issue the SET MAX FREEZE LOCK 
command when in this state. 


SM3: Set_Max_Frozen: This state is entered when a SET MAX FREEZE LOCK command is received. 


In this state, the device may not transition to any other state except by a power cycling. When in this mode 
bit 8 of word 86 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data shall be set to one. 


Transition SM3:SM3: When a SET MAX ADDRESS, SET MAX SET PASSWORD, SET MAX UNLOCK, 
SET MAX FREEZE LOCK, or SET MAX LOCK command is received, the command shall be aborted and the 
device shall make a transition to the SM3: Set_Max_Frozen state. 


4.10 CompactFlash™ Association (CFA) feature set 


The optional CompactFlash™ Association (CFA) feature set provides support for solid state memory devices. 
A device that implements the CFA feature set shall implement the following minimum set of commands: 


— CFA REQUEST EXTENDED ERROR CODE 
— CFAWRITE SECTORS WITHOUT ERASE 

— CFA ERASE SECTORS 

— CFAWRITE MULTIPLE WITHOUT ERASE 

— CFA TRANSLATE SECTOR 

— SET FEATURES Enable/Disable 8-bit transfer 


Devices reporting the value 848Ah in IDENTIFY DEVICE data word 0 or devices having bit 2 of IDENTIFY 


DEVICE data word 83 set to one shall support the CFA feature Set. If the CFA feature set is implemented, 
all five commands shall be implemented. 
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Support of DMA commands is optional for devices that support the CFA feature set. 


The CFA ERASE SECTORS command preconditions the sector for a subsequent CFA WRITE SECTORS 
WITHOUT ERASE or CFA WRITE MULTIPLE WITHOUT ERASE command to achieve higher performance 
during the write operation. The CFA TRANSLATE SECTOR command provides information about a sector 
such as the number of write cycles performed on that sector and an indication of the sector's erased 
precondition. The CFA REQUEST EXTENDED ERROR CODE command provides more detailed error 
information. 


Command codes B8h through BFh are reserved for assignment by the CompactFlash™ Association. 
4.11 Removable Media Status Notification and Removable Media feature sets 


This section describes two feature sets that secure the media in removable media storage devices using the 
ATA/ATAPI interface protocols. The Removable Media Status Notification feature set is intended for use in 
both devices implementing the PACKET Command feature set and those not implementing the PACKET 
Command feature set. The Removable Media feature set is intended for use only in devices not 
implementing the PACKET Command feature set. Only one of these feature sets shall be enabled at any 
time. If the Removable Media Status Notification feature set is in use then the Removable Media feature set 
is disabled and vice versa. 


The reasons for implementing the Removable Media Status Notification feature Set or the Removable Media 
feature set are: 


— to prevent data loss caused by writing to new media while still referencing the previous media’s 
information. 


— to prevent data loss by locking the media until completion of a cached write. 
— to prevent removal of the media by unauthorized persons. 


4.11.1 Removable Media Status Notification feature set 


The Removable Media Status Notification feature set is the preferred feature set for securing the media in 
removable media storage devices. This feature set uses the SET FEATURES command to enable 
Removable Media Status Notification. Removable Media Status Notification gives the host system maximum 
control of the media. The host system determines media status by issuing the GET MEDIA STATUS 
command and controls the device eject mechanism via the MEDIA EJECT command (for devices not 
implementing the PACKET Command feature set) or the START/STOP UNIT command (for devices 
implementing the PACKET Command feature set, See Clause 1). While Removable Media Status 
Notification is enabled devices not implementing the PACKET Command feature set execute MEDIA LOCK 
and MEDIA UNLOCK commands without changing the media lock state (no-operation). While Removable 
Media Status Notification is enabled the eject button does not eject the media. 


Removable Media Status Notification is persistent through medium removal and insertion and is only 
disabled via the SET FEATURES command, hardware reset, software reset, the DEVICE RESET command, 
the EXECUTE DEVICE DIAGNOSTIC command, or power-on reset. Removable Media Status Notification 
shall be re-enabled after any of the previous reset conditions occur. All media status is reset when 
Removable Media Status Notification is disabled because a reset condition occurred. Any pending media 
change or media change request is cleared when the Removable Media Status Notification reset condition 
occurs. 


The following commands are defined to implement the Removable Media Status Notification feature set. 


— GET MEDIA STATUS 

— MEDIA EJECT 

— SET FEATURES (Enable media status notification) 
— SET FEATURES (Disable media status notification) 
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NOTE -— Devices implementing the PACKET Command feature set control the media eject mechanism via 
the START/STOP UNIT command packet. 


The preferred sequence of events to use the Removable Media Status Notification feature set is as follows: 


a) Host system checks whether or not the device implements the PACKET Command feature set via 
the device signature in the Command Block registers. 

b) Host system issues the IDENTIFY DEVICE command or the IDENTIFY PACKET DEVICE command 
and checks that the device is a removable media device and that the Removable Media Status 
Notification feature set is supported. 

c) Host system uses the SET FEATURES command to enable Media Status Notification that gives 
control of the media to the host. At this time the host system checks the LBA High register to 
determine if: 

— the device is capable of locking the media. 
— the device is capable of power ejecting the media. 
— Media Status Notification was enabled prior to this command. 

d) Host system periodically checks media status using the GET MEDIA STATUS command to 
determine if any of the following events occurred: 

— no media is present in the device (NM). 
— media was changed since the last command (MC). 
— amedia change request has occurred (MCR). 


— media is write protected (WP). 
4.11.2 Removable Media feature set 


The Removable Media feature set is intended only for devices not implementing the PACKET Command 
feature set. This feature set operates with Media Status Notification disabled. The MEDIA LOCK and MEDIA 
UNLOCK commands are used to secure the media and the MEDIA EJECT command is used to remove the 
media. While the media is locked, the eject button does not eject the media. Media status is determined by 
checking the media status bits returned by the MEDIA LOCK and MEDIA UNLOCK commands. 


Power-on reset, hardware reset, and the EXECUTE DEVICE DIAGNOSTIC command clear the Media Lock 
(LOCK) state and the Media Change Request (MCR) state. Software reset clears the Media Lock (LOCK) 
state, clears the Media Change Request (MCR) state, and preserves the Media Change (MC) state. 


The following commands are defined to implement the Removable Media feature set. 


— MEDIA EJECT 
— MEDIA LOCK 
— MEDIA UNLOCK 


The preferred sequence of events to use the Removable Media feature set is as follows: 


a) Host system checks whether or not the device implements the PACKET Command feature set via 
the device signature in the Command Block registers. 
b) Host system issues the IDENTIFY DEVICE command and checks that the device is a removable 
media device and that the Removable Media feature set is supported. 
c) Host system periodically issues MEDIA LOCK commands to determine if: 
— no media is present in the device (NM) - media is locked if present. 


— amedia change request has occurred (MCR). 


4.12 Power-Up In Standby feature set 
The optional Power-Up In Standby feature set allows devices to be powered-up into the Standby power 


management state to minimize inrush current at power-up and to allow the host to sequence the spin-up of 
devices. This optional feature set may be enabled or disabled via the SET FEATURES command or may be 
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enabled by use of a jumper or similar means, or both. When enabled by a jumper, the feature set shall not be 
disabled via the SET FEATURES command. The IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data 
indicates whether this feature set is implemented and/or enabled. 


The enabling of this feature set shall be persistent after power-down and power-up. When this feature set is 
enabled, the device shall power-up into Standby. 


A device may implement a SET FEATURES subcommand that notifies the device to spin-up to the Active 
state when the device has powered-up into Standby. If the device implements this SET FEATURES 
subcommand and power-up into Standby is enabled, the device shall remain in Standby until the SET 
FEATURES subcommand is received. If the device implements this SET FEATURES subcommand, the fact 
that the feature is implemented is reported in the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE 
response. 


If the device: 


— implements the Enable/disable Power-up in Standby subcommand, 

— power-up into Standby is enabled, and 

— anIDENTIFY DEVICE or IDENTIFY PACKET DEVICE is received while the device is in Standby as 
a result of powering up into Standby, 


the device shall respond to the command and remain in Standby without spinning-up. 


If the device has IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data that requires access to the media, 
the device shall set word 0 bit 2 to one to indicate that the response is incomplete. At a minimum, word O and 
word 2 shall be correctly reported. Those fields that cannot be provided shall be filled with zeros. Once the 
full IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data has been accessed, a full response shall be 
returned until the next power-down/power-up sequence has taken place. 


If the device does not implement the SET FEATURES subcommand to spin-up the device after power-up 
and power-up into Standby is enabled, the device shall spin-up upon receipt of the first command that 
requires the device to access the media. 


4.13 Automatic Acoustic Management (AAM) feature set 


The Automatic Acoustic Management feature set is an optional feature set that allows the host to select an 
acoustic management level. The acoustic management level ranges from the setting of OOh to FFh, although 
many levels are currently reserved (See Table 43). Device performance and acoustic emanation may 
increase with increasing acoustic management levels. The acoustic management levels may contain 
discrete bands. For example, a device may implement one acoustic management method from level 80h to 
AOh, and a higher performance, higher acoustic emanation method from level A1h to FEh. 


The Automatic Acoustic Management feature set uses the following functions: 
— ASET FEATURES subcommand to enable the Automatic Acoustic Management feature set 


— ASET FEATURES subcommand to disable the Automatic Acoustic Management feature set 


The IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data indicates if the Automatic Acoustic 
Management feature set is supported, if the Automatic Acoustic Management feature set is enabled, and the 
current automatic acoustic management level if the Automatic Acoustic Management feature set is enabled. 
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4.14 48-bit Address feature set 


The optional 48-bit Address feature set allows devices with capacities up to 281,474,976,710,655 sectors. 
This allows device capacity up to 144,115,188,075,855,360 bytes. In addition, the number of sectors that 
may be transferred by a single command are increased by increasing the allowable sector count to 16 bits. 
The commands in the 48-bit Address feature set are prohibited from use for devices implementing the 
PACKET Command feature set. 


Commands unique to the 48-bit Address feature set are: 


— FLUSH CACHE EXT 

— READ DMA EXT 

— READ DMA QUEUED EXT 

— READ MULTIPLE EXT 

— READ NATIVE MAX ADDRESS EXT 
— READ SECTOR(S) EXT 

— READ VERIFY SECTOR(S) EXT 
— SET MAX ADDRESS EXT 

— WRITE DMA EXT 

— WRITE DMA FUA EXT 

— WRITE DMA QUEUED EXT 

— WRITE DMA QUEUED FUA EXT 
— WRITE MULTIPLE EXT 

— WRITE MULTIPLE FUA EXT 

— WRITE SECTOR(S) EXT 


The 48-bit Address feature set operates in LBA only. Devices implementing the 48-bit Address feature set 
shall also implement commands that use 28-bit addressing. 28-bit and 48-bit commands may be intermixed. 
Support of the 48-bit Address feature set is indicated in the IDENTIFY DEVICE response. 


In a device implementing the 48-bit Address feature set, the Features register, the Sector Count register, the 
LBA Low register, the LBA Mid register, and the LBA High register are each a two byte deep FIFO. Each 
time one of these registers is written, the new content written is placed into the “most recently written” 
location and the previous content of the register is moved to “previous content” location. For example, when 
a 48-bit Address feature set READ SECTOR(S) EXT command is written to the device Command register, 
the address used by the command is as described in Table 5. 


Table 5 - 48-bit addresses 
Features Reserved Reserved 
Sector Count Sector count (7:0) Sector count (15:8) 
LBA Low LBA (7:0) LBA (31:24) 
LBA Mid LBA (15:8) LBA (39:32) 
LBA High LBA (23:16) LBA (47:40) 
Device register Bits 7 and 5 are obsolete, the LBA bit shall be set to one, the Reserved 
DEV bit shall indicate the selected device, bits (3:0) are 
reserved 


When a READ SECTOR(S) command utilizing 28-bit addressing is written to the device Command register, 
the address used by the command is as described in Table 6. Thus commands utilizing 28-bit addressing still 
function as described in the command descriptions. 
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Table 6 - 28-bit addresses 

Register “most recently written” “previous content” 
Features na 

Sector Count Sector count (7:0) 


LBA Low LBA (7:0) 

LBA Mid LBA (15:8) 

LBA High LBA (23:16) 
Device register LBA (27:24) 


The host may read the “previous content” of the Features, Sector Count, LBA Low, LBA Mid, and LBA High 
registers by first setting the High Order Bit (HOB, bit 7) of the Device Control register to one and then reading 
the desired register. If HOB (bit 7) in the Device Control register is cleared to zero the host reads the “most 
recently written” content when the register is read. A write to any Command Block register shall cause the 
device to clear the HOB bit to zero in the Device Control register. The “most recently written” content always 
gets written by a register write regardless of the state of HOB (bit 7) in the Device Control register. 


Registers are written and read as described in Volume 3, Clause 5. 


The device shall indicate support of the 48-bit Address feature set in the IDENTIFY DEVICE response. In 
addition, IDENTIFY DEVICE data words (103:100) contain the maximum user LBA + 1 that is accessible by 
48-bit addressable commands . 


If the value contained in IDENTIFY DEVICE data words (103:100) is equal to or less than 268,435,455, then 
the content of words (61:60) shall be as described in 4.2.1. If the value in contained IDENTIFY DEVICE data 
words (103:100) is greater than 268,435,455, then the maximum value in words (61:60) shall be 
268,435,455. That is, if the device contains greater than the capacity addressable with 28-bit commands, 
words (61:60) shall describe the maximum capacity that can be addressed by 28-bit commands. 


When the 48-bit Address feature set is implemented, the native maximum address is the highest address 
accepted by the device in the factory default condition using a 48-bit Address feature set command. The 
native maximum address is the value returned by a READ NATIVE MAX ADDRESS EXT command. If the 
native maximum address of a device is equal to or less than 268,435,455, a READ NATIVE MAX ADDRESS 
shall return the native maximum address. If the native maximum address is greater than 268,435,455, a 
READ NATIVE MAX ADDRESS command shall cause the device to return a maximum value of 
268,435,454. 


When the 48-bit Address feature set is implemented, the SET MAX ADDRESS command shall execute as 
described in 6.50.1. However, in addition to modifying the content of words (61:60), the new content of 
(61:60) shall also be placed in words (103:100). When a SET MAX ADDRESS EXT command is issued and 
the address requested is greater than 268,435,455, words (103:100) shall be modified to reflect the 
requested value but words 60, and 61 shall not be modified. When a SET MAX ADDRESS EXT command is 
issued and the address requested is equal to or less than 268,435,455, words (103:100) shall be modified to 
reflect the requested value and words 60, and 61 shall be modified as described in 6.50.1.8. 


If a Host Protected Area has been created using the SET MAX ADDRESS command, all SET MAX 
ADDRESS EXT commands shall result in command aborted until the Host Protected Area is eliminated by 
use of the SET MAX ADDRESS command with the address value returned by the READ NATIVE MAX 
ADDRESS command. If a Host Protected Area has been created using the SET MAX ADDRESS EXT 
command, all SET MAX ADDRESS commands shall result in command aborted until the Host Protected 
Area is eliminated by use of the SET MAX ADDRESS EXT command with the address value returned by the 
READ NATIVE MAX ADDRESS EXT command. 


The WRITE DMA FUA EXT, WRITE DMA QUEUED FUA EXT, and WRITE MULTIPLE FUA EXT commands 


are unique in that regardless whether or not caching is enabled in the device, the user data shall be written 
to the media before ending status for the command is reported. 
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4.15 Device Configuration Overlay feature set 


The optional Device Configuration Overlay feature set allows a utility program to modify some of the optional 
commands, modes, and feature sets that a device reports as supported in the IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE command data as well as the capacity reported. 


Commands unique to the Device Configuration Overlay feature set use a single command code and are 
differentiated from one another by the value placed in the Features register. These commands are: 


— DEVICE CONFIGURATION FREEZE LOCK 
— DEVICE CONFIGURATION IDENTIFY 

— DEVICE CONFIGURATION RESTORE 

— DEVICE CONFIGURATION SET 


The Device Configuration Overlay feature set may affect words (61:60), 63, (88:82), and(103:100) of the 
IDENTIFY DEVICE and IDENTIFY PACKET DEVICE command responses. Certain bits in these words that 
indicate that a command, mode, capacity, or feature set is supported and enabled may be cleared by a 
DEVICE CONFIGURATION SET command. For a particular command, mode, capacity, or feature set, when 
a bit is cleared indicating that the device does not support the feature, the device shall not provide the 
feature. Also, the maximum capacity of the device may be reduced. Since a Host Protected Area may be lost 
if the capacity of the device is reduced, when a Host Protected Area is set the DEVICE CONFIGURATION 
SET command shall cause the device to return command aborted. The address value returned by a READ 
NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT command is modified by the DEVICE 
CONFIGURATION SET command modifying the maximum capacity of the device. If a DEVICE 
CONFIGURATION FREEZE LOCK command has been issued since the device powered-up, the DEVICE 
CONFIGURATION SET command shall cause the device to return command aborted. The settings made by 
a DEVICE CONFIGURATION SET command are maintained over power-down and power-up. 


A DEVICE CONFIGURATION IDENTIFY command specifies the selectable commands, modes, capacity, 
and feature sets that the device is capable of supporting. After the execution of a DEVICE 
CONFIGURATION SET command this information is no longer available from an IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE command. 


A DEVICE CONFIGURATION RESTORE command disables an overlay that has been set by a DEVICE 
CONFIGURATION SET command and returns the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE 
command data to that indicated by the DEVICE CONFIGURATION IDENTIFY command. Since a Host 
Protected Area may be lost if the capacity of the device is reduced, when a Host Protected Area is set the 
DEVICE CONFIGURATION RESTORE command shall cause the device to return command aborted. If a 
DEVICE CONFIGURATION FREEZE LOCK command has been issued since the device powered-up, the 
DEVICE CONFIGURATION RESTORE command shall cause the device to return command aborted. 


A DEVICE CONFIGURATION FREEZE LOCK command prevents accidental modification of the state of the 
Device Configuration Overlay feature set. A device always powers-up with configuration freeze lock not set. 
After a successful DEVICE CONFIGURATION FREEZE LOCK command is executed, all DEVICE 
CONFIGURATION SET, DEVICE CONFIGURATION IDENTIFY, and DEVICE CONFIGURATION 
RESTORE commands are aborted by the device until the device is powered-down and powered-up again. 
The freeze locked state is not affected by hardware or software reset. 


Figure 7 and the text following the figure describe the operation of the Device Configuration Overlay feature 
set. 
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DCoo: Factory_config DCO1: DCO_locked 


DEVICE CONFIGURATION 
FREEZE LOCK command 


DCOO0:DCO1 


DEVICE CONFIGURATION 
RESTORE or Invalid DEVICE 
CONFIGURATION SET 
command (see text) 


DCO0:DCOO 


DEVICE CONFIGURATION FREEZE LOCK, 
DEVICE CONFIGURATION IDENTIFY, 
DEVICE CONFIGURATION RESTORE, or 
DEVICE CONFIGURATION SET command 


Power-up with factory 
configuration set 


DCO1:DCO1 


DCO2: Reduced_config 
Valid DEVICE 
CONFIGURATION SET 
command (see text) 


DCO0:DCO2 


DEVICE CONFIGURATION 
FREEZE LOCK command 


DCO2:DCO1 
DEVICE CONFIGURATION SET 
or Invalid DEVICE 
CONFIGURATION RESTORE 
command (see text) 
DCO2:DCO2 


Valid DEVICE 
CONFIGURATION RESTORE 
command (see text) 


DCO2:DCOO0 


Power-up with reduced 
configuration set 


Figure 7 - Device Configuration Overlay state diagram 


DCOO: Factory_config State: This state is entered when the device powers-up with the factory 
configuration set or a valid DEVICE CONFIGURATION RESTORE command is received. 


When in this state, the device shall support all commands, modes, features sets, and the capacity indicated 
by the response to a DEVICE CONFIGURATION IDENTIFY command. 


Transition DCO0:DCO1: When a DEVICE CONFIGURATION FREEZE LOCK command is received, the 
device shall return successful command completion and make a transition to the DCO1: DCO_locked state. 


Transition DCO0:DCO2: When a valid DEVICE CONFIGURATION SET command is received, the device 
shall return successful command completion and make a transition to the DCO2: Reduced_config state. See 
Transition DCOO:DCOO for the definition of conditions that make a DEVICE CONFIGURATION SET 
command invalid. This transition is made even if the configuration described by the DEVICE SET 
CONFIGURATION SET command is the same as the factory configuration. 


Transition DCO0:DCOO0: When a DEVICE CONFIGURATION RESTORE command is received, the device 
shall return command aborted and make a transition to the DCOO: Factory_config state. When an invalid 
DEVICE CONFIGURATION SET command is received, the device shall return command aborted and make 
a transition to the DCOO: Factory_config state. A DEVICE CONFIGURATION SET command is invalid if the 
DEVICE CONFIGURATION SET command requests: 


— aHost Protected Area has been established using the SET MAX ADDRESS command. 

— the elimination of support of a Multiword or Ultra DMA mode if that mode is currently selected or a 
higher numbered mode is currently selected. 

— the elimination of support of the Host Protected Area feature set if a Host Protected Area has been 
established using a SET MAX ADDRESS command. 
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— the elimination of support of the Power-up in Standby feature set if the feature set has been enables 
by a jumper. 

— the elimination of support of the Security feature set if the feature set has been enabled. 

— the elimination of support of the SMART feature set if bits (2:1) of word 7 are not cleared to zero or if 
the SMART feature set has been enabled by use of the SMART ENABLE OPERATIONS command. 


DCO1: DCO_locked State: This state is entered when a DEVICE CONFIGURATION RESTORE 
command is received. 


When in this state, all DEVICE CONFIGURATION FREEZE LOCK, DEVICE CONFIGURATION IDENTIFY, 
DEVICE CONFIGURATION SET, or DEVICE CONFIGURATION RESTORE commands shall return 
command abort and shall remain in the locked state. 


Transition DCO1:DCO1: When a DEVICE CONFIGURATION FREEZE LOCK, DEVICE CONFIGURATION 
IDENTIFY, DEVICE CONFIGURATION SET, or DEVICE CONFIGURATION RESTORE command is 
received, the device shall return command aborted and make a transition to the DCO1: DCO_locked state. 


DCO2: Reduced_config State: This state is entered when the device powers-up with a reduced 
configuration set or a valid DEVICE CONFIGURATION SET command is received. 


When in this state, the device shall support all commands, modes, features sets, and the capacity specified 
by the DEVICE CONFIGURATION SET command that caused this state to be entered. 


Transition DCO2:DCO1: When a DEVICE CONFIGURATION FREEZE LOCK command is received, the 
device shall return successful command completion and make a transition to the DCO1: DCO_locked state. 


Transition DCO2:DCOO0: When a valid DEVICE CONFIGURATION RESTORE command is received, the 
device shall return successful command completion and make a transition to the DCOO: Factory_config 
state. See Transition DCO2:DCO2 for the definition of conditions that make a DEVICE CONFIGURATION 
RESTORE command invalid. 


Transition DCO2:DCO2: When a DEVICE CONFIGURATION SET command is received, the device shall 
return command aborted and make a transition to the DCO2: Reduced_config state. When an invalid 
DEVICE CONFIGURATION RESTORE command is received, the device shall return command aborted and 
make a transition to the DCO2: Reduced_config state. A DEVICE CONFIGURATION RESTORE command 
is invalid if a Host Protected Area has been established using the SET MAX ADDRESS command. 


4.16 Media Card Pass Through Command feature set 


The Media Card Pass Through commands are implemented by a Media Pass Through device. A device 
implementing the Media Card Pass Through Command feature set is a bridge to one or more types of media 
card storage devices. The bridge device responds to the same command set as described in 4.3.1 and to the 
commands included in this feature set. 


Use of the Media Card Pass Through Command feature set is prohibited for PACKET devices. 


The Media Card Pass Through Command feature set uses the command codes Dih, D2h, D3h, and D4h 
and bits in word 84 and word 87 of the IDENTIFY DEVICE response. The command codes D2h through D4h 
are reserved for the Media Card Pass Through Command feature set if this feature set is enabled by the 
CHECK MEDIA CARD TYPE command (D1h). This feature set embeds small-format flash memory card 
commands inside the ATA commands. The adapter’s firmware passes the embedded memory card’s 
command to the memory card as is from the ATA command. The Media Card Pass Through Command 
feature set reduces the number of commands required for this feature set regardless of the number or type 
of memory card commands. It also reduces the adapter’s firmware overhead in processing them. As new 
memory cards types are defined in the market, they can all be supported within this one feature. 


The commands unique to the Media Card Pass Through Command feature set are: 
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— CHECK MEDIA CARD TYPE 
— Command codes D2h through D4h 


The CHECK MEDIA CARD TYPE command returns the supporting status of the device to this feature set. It 
also enables and disables the device from running the Media Card Pass Through Command feature set. 
When the Media Card Pass Through Command feature set is disabled, the command codes D2h through 
D4h shall not be interpreted as Media Card Pass Through Command feature set commands and the device 
shall return command aborted. Power-on, hardware, or software reset shall disable the Media Card Pass 
Through Command feature set. 


The definitions of the commands D2h-D4h are media card type dependent. Table 7 lists the Media card 
types and their associated reference document: 


Table 7 - Media Card type references 


Media Card Type 


SD Card SD Card ATA Command Extension (SDA 3C) 
Smart Media Smart Media ATA Command Extension (SSFDC Forum) 


4.17 Streaming feature set 


The Streaming feature set is an optional feature set that allows a host to request delivery of data from a 
contiguous logical block address range within an allotted time. This places a priority on time to access the 
data rather than the integrity of the data. Streaming feature set commands only support 48-bit addressing. 


A device that implements the Streaming feature set shall implement the following minimum set of 
commands: 


— CONFIGURE STREAM 

— READ STREAM EXT 

— WRITE STREAM EXT 

— READ STREAM DMA EXT 
— WRITE STREAM DMA EXT 
— READ LOG EXT 

— WRITE LOG EXT 


Support of the Streaming feature set is indicated in IDENTIFY DEVICE data word 84 bit 4. 


NOTE -— PIO versions of these commands limit the transfer rate (16.6 MB/s), provide no CRC protection, and 
limit status reporting as compared to a DMA implementation. 


4.17.1 Streaming commands 


The streaming commands are defined to be time critical data transfers rather than the standard data integrity 
critical commands. Each command shall be completed within the time specified in the CONFIGURE 
STREAM command or in the streaming command itself in order to ensure the stream requirements of the AV 
type application. The device may execute background tasks as long as the READ STREAM and WRITE 
STREAM command execution time limits are still met. 


Using the CONFIGURE STREAM command, the host may define the various stream properties including the 
default Command Completion Time Limit (CCTL) to assist the device in setting up its caching for best 
performance. If the host does not use a CONFIGURE STREAM command, the device shall use the CCTL 
specified in each streaming command, and the time limit is effective for one time only. If the CCTL is not set 
by a CONFIGURE STREAM command, the operation of a streaming command with a zero CCTL is device 
vendor specific. If Stream ID is not set by a CONFIGURE STREAM command, the device shall operate 
according to the Stream ID set by the streaming command. The operation is device vendor specific. 
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The streaming commands may access any user LBA on a device. These commands may be interspersed 
with non-streaming commands, but there may be an impact on performance due to the unknown time 
required to complete the non-streaming commands. 


The streaming commands should be issued using a specified minimum number of sectors transferred per 
command, as specified in word 95 of the IDENTIFY DEVICE response. The transfer length of a request 
should be a multiple of the minimum number of sectors per transfer. 


The host provided numeric stream identifier, Stream ID, may be used by the device to configure its resources 
to support the streaming requirements of the AV content. One Stream ID may be configured for each read 
and write operation with different command completion time limits by each CONFIGURE STREAM 
command. 


4.17.1.1 Urgent bit 


The Urgent bit in the READ STREAM and WRITE STREAM commands specifies that the command should 
be completed in the minimum possible time by the device and shall be completed within the specified 
Command Completion Time Limit. 


4.17.1.2 Flush to Disk bit 


The Flush to Disk bit in the WRITE STREAM command specifies that all data for the specified stream shall 
be flushed to the media before posting command completion. If a host requests flushes at times other than 
the end of each Allocation Unit, streaming performance may be degraded. The SET FEATURES command 
to enable/disable caching shall not affect caching for streaming commands. 


4.17.1.3 Not Sequential bit 


The Not Sequential bit specifies that the next read stream command with the same Stream ID may not be 
sequential in LBA space. This information helps the device with pre-fetching decisions. 


4.17.1.4 Read Continuous bit 


If the Read Continuous bit is set to one for the command, the device shall transfer the requested amount of 
data to the host within the Command Completion Time Limit even if an error occurs. The data sent to the 
host by the device in an error condition is vendor specific. 


4.17.1.5 Write Continuous bit 


If the Write Continuous bit is set to one for the command, and an error is encountered, the device shall 
complete the request without posting an error. If an error cannot be resolved within the Command 
Completion Time Limit, the erroneous section on the media may be unchanged or may contain undefined 
data. A future read of this area may not report an error, even though the data is erroneous. 


4.17.1.6 Handle Streaming Error bit 


The Handle Streaming Error bit specifies to the device that this command starts at the LBA of a recently 
reported error section, so the device may attempt to continue its corresponding error recovery sequence 
where it left off earlier. This mechanism allows the host to schedule error recovery and defect management 
for content critical data. 


4.17.2 Streaming Logs 
The Streaming Data Transfer feature set requires two error logs and one performance log. These logs are 
accessed via the READ LOG EXT command. The information included in the error logs is volatile and is not 


maintained across power cycles, hard resets, or sleep. These error logs are 512 bytes in length and retain 
the last 31 errors that occurred during any Streaming Data transfer. 
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The Streaming Performance log provides specific drive performance characteristics to the host that allows 
for calculating of streaming performance values. The contents of the Streaming Performance Parameters 
Log may be affected by the host issuing a SET FEATURES subcommand 42h, C2h, or 43h (Automatic 
Acoustic Management, and Typical Host Interface Sector Time). The host should base its calculations on the 
larger of its Typical Host Interface Sector Time and the device reported Sector Time values, and on the sum 
of the device reported Access Time values and any additional latency that only the host is aware of (host 
command overhead, etc). 
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4.18 General Purpose Logging feature set 


The General Purpose Logging feature set provides a mechanism for accessing logs in a device. These logs 
are associated with specific feature sets such as SMART. Support of the individual logs is determined by 
support of the associated feature set. If the device supports a particular feature set, support for any 
associated log(s) is mandatory. 


Support for the General Purpose Logging feature set shall not be disabled. If the feature set associated with 
a requested log is disabled, the device shall return command abort. 


If the General Purpose Logging feature set is implemented, the following commands shall be supported: 


-- READ LOG EXT 
-- WRITE LOG EXT 


4.19 Overlapped feature set 
Serial implementations of ATA have different requirements (See Clause 5). 


The optional Overlap feature set allows devices that require extended command time to perform a bus 
release so that the other device on the bus may be used. To perform a bus release the device shall clear 
both DRQ and BSY to zero. When selecting the other device during overlapped operations, the host shall 
disable assertion of INTRQ via the nlEN bit on the currently selected device before writing the Device 
register to select the other device and then may re-enable interrupts. 


The only commands that may be overlapped are: 


— NOP (with a subcommand code other than OOh) 
— PACKET 

— READ DMA QUEVED 

— READ DMA QUEUED EXT 

— SERVICE 

— WRITE DMA QUEUVED 

— WRITE DMA QUEUED EXT 

— WRITE DMA QUEUED FUA EXT 


For the PACKET command, overlap is specified by the OVL bit in the Features register when the PACKET 
command is issued. 


If the device supports PACKET command overlap, the OVL bit is set to one in the Features register and the 
Release interrupt has been enabled via the SET FEATURES command, then the device shall perform a bus 
release when the command packet has been received. This allows the host to select the other device to 
execute commands. When the device is ready to continue the command, the device sets SERV to one, and 
asserts INTRQ if selected and nlEN is cleared to zero. The host then issues the SERVICE command to 
continue the execution of the command 


If the device supports PACKET command overlap, the OVL bit is set to one in the Features register and the 
Release interrupt has been disabled via the SET FEATURES command, then the device may or may not 
perform a bus release. If the device is ready to complete execution of the command, the device may 
complete the command immediately as described in the non-overlap case. If the device is not ready to 
complete execution of the command, the device may perform a bus release and complete the command as 
described in the previous paragraph. 


For the READ DMA QUEUED and WRITE DMA QUEUED commands, the device may or may not perform a 
bus release. If the device is ready to complete execution of the command, the device may complete the 
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command immediately. If the device is not ready to complete execution of the command, the device may 
perform a bus release and complete the command via a service request. 


If a device has an outstanding command that has been released, the device can only indicate that service is 
required when the device is selected. This implies that the host has to poll each device to determine if a 
device is requesting service. The polling can be performed at the host either by hardware or by a software 
routine. The latter implies a considerable host processor overhead. Hardware polling is initiated by the NOP 
Auto Poll command. 


The NOP Poll command is a host adapter function and is ignored by the device. The host software can test 
for the support of this feature by issuing the NOP Auto Poll subcommand and examining the Status register. 
If the host adapter does not support this feature, the response received by the host will be from the device 
with the ERR bit set to one. If the host adapter does support the command, the response will be from the 
host adapter with the ERR bit cleared to zero. The only action taken by a device supporting the Overlapped 
feature set will be to return the error indication in the Status register and to not abort any outstanding 
commands. 


When this command is received, the user data shall be written to the device media before ending status for 
the command is reported regardless of the state of any write cache or queue. A queue shall not be aborted. 


4.20 Queued feature set 


The Queued feature set allows the host to issue concurrent commands to the same device. The Queued 
feature set is optional if the Overlap feature set is supported. Only commands included in the Overlapped 
feature set may be queued. The queue contains all commands for which command acceptance has occurred 
but command completion has not occurred. If a queue exists when a non-queued command is received, the 
non-queued command shall be command aborted and the commands in the queue shall be discarded. The 
ending status shall be command aborted and the results are indeterminate. 


The maximum queue depth supported by a device shall be indicated in word 75 of the IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE response. 


A queued command shall have a Tag provided by the host in the Sector Count register to uniquely identify 
the command. When the device restores register parameters during the execution of the SERVICE 
command, this Tag shall be restored so that the host may identify the command for which status is being 
presented. A Tag value may be any value between 0 and 31, regardless of the queue depth supported. If a 
queued command is issued with a Tag value that is identical to the Tag value for a command already in the 
queue, the entire queue shall be aborted including the new command. The ending status shall be command 
aborted and the results are indeterminate. If any error occurs, the command queue shall be aborted. 


When the device is ready to continue the processing of a bus released command and BSY and DRQ are 
both cleared to zero, the device requests service by setting SERV to one, setting a pending interrupt, and 
setting Interrupt Pending if selected and if nlIEN is cleared to zero. SERV shall remain set until all commands 
ready for service have been serviced. A read of the Status register or a write of the Command register shall 
clear the Interrupt Pending. 


When the device is ready to continue the processing of a bus released command and BSY or DRQ is set to 
One (i.e., the device is processing another command on the bus), the device requests service by setting 
SERV to one. SERV shall remain set until all commands ready for service have been serviced. At command 
completion of the current command processing (i.e., when both BSY and DRQ are cleared to zero), the 
device shall process Interrupt Pending and INTRQ per the protocol for the command being completed. No 
additional INTRQ assertion shall occur due to other commands ready for service until after the device’s 
SERV bit has been cleared to zero. 


When the device receives a new command while queued commands are ready for service, the device shall 
execute the new command and process Interrupt Pending and INTRQ per the protocol for the new 
command. If the queued commands ready for service still exist at command completion of this command, 
SERV remains set to one but no additional INTRQ assertion shall occur due to commands ready for service. 
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When queuing commands, the host shall disable INTRQ assertion via the nlEN bit before writing a new 
command to the Command register and may re-enable INTRQ assertion after writing the command. When 
reading status at command completion of a command, the host shall check the SERV bit since the SERV bit 
may be set because the device is ready for service associated with another command. The host receives no 
additional INTRQ assertion to indicate that a queued command is ready for service. 


4.21 Long Physical Sector Feature Set for Non-Packet Devices 


The purpose of the long physical sector feature set is to allow increased media format efficiency. During write 
operations devices calculate and error correction code, ECC, and write the ECC on the media following the 
data. ECC encoding is more efficient when used over a larger amount of data. 


The long physical sector feature set allows a device to be formatted so that there are multiple logical sectors 
per physical sector on the media. Each physical sector has an ECC field. This allows, for example, a device 
to have 2048 word physical sectors each containing 8 logical sectors, or one ECC field per 8 256 word 
logical sectors, See Figure 8 example 3. 

A performance penalty may be incurred when writing to devices that implement long physical sector feature 
set. A physical sector is read or written in a single operation. If a host system does not write all of the logical 
sectors in a physical sector during a single command the device may need to read the logical sectors that 
are not to be changed into memory and then write the entire physical sector, see Appendix C. 


1) Conventional Logical Sector Format: 512 Bytes Per LBA Address 


512 B--512 B--512 B--512 B--512 B--512 B--512 B--512 Br 
2) Long Logical Sector Format Example: 524 Bytes Per LBA Address 
/- 524 Bao 524 Bi 524 B—— 524 cs 524 oi 524 E> 524 B—| 


3) Long Physical Sector Format Example: 512 Bytes Per LBA Address, 2048 
Bytes Per Physical Sector 


[+512 p-s12 p-512 p-s12 p-512 p-s12 p-512 p-s12 B | 


Physical Sector 0 Physical Sector 1 


4) Long Logical and Long Physical Sector Format Example: 524 Bytes Per LBA 
Address, 2096 Bytes Per Physical Sector 


|- 524 B |. 524 B |. 524 p—-524 B —- 524 B | 524 B |. 524 B—| 


Physical Sector 0 Physical Sector 1 


Figure 8 - Long Logical and long Physical Sector Example 
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4.22 Long Logical Sector Feature Set for Non-Packet Devices 


The purpose of the long logical sector feature set is to allow additional data words per sector for server 
applications. Sectors with 520 or 528 bytes are typical. Devices with long logical sectors set IDENTIFY 
DEVICE data word 106 bit 13 to 1. The Long Logical Sector length is described by IDENTIFY DEVICE data 
words 117-118. 


Devices that implement the Long Logical Sector Feature set are not backward compatible with applications 
that use 256 word logical sectors, e.g. desktop and laptop system. 


Table 8 - Long Logical Sector Function 


jp CFA ERASE SECTORS fs 
| CFAREQUESTEXTENDEDERRORCODE | 
| = CFAWRITE SECTORS WITHOUTERASE | 
| CHECK MEDIACARDTYPE | 
| CHECK POWERMODE | 
| CONFIGURE STREAM | 
| DEVICE CONFIGURATION, PO 
po CDEVICERESET OP 
| EXECUTE DEVICE DIAGNOSTIC | 
Pp FLUSH CACHE PE 
Po FLUSHCACHEEXT OP 
po GETMEDIASTATUS | 
| IDENTIFY PACKETDEVICE | 
[Coenen © =e | 
PILE IMMEDIATE PE 
po MEDIAEJECT 
po MEDIALOCK, 
po MEDIAUNLOCK, 
pO NOR 
| SMREADNATIVEMAXADDRESS | 
| = FREAD NATIVEMAXADDRESSEXT | 
| READ VERIFY SECTOR(S)EXT | 


(continued) 
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Table 8 - Long Logical Sector Function (continued) 


| SC SECURITYERASEPREPARE | 
| CSECURITYFREEZELOCK | 
pO SEEK 
pe SERVICE 
Po SETFEATURES OP 
po SETMAXLOCK 
| CM SETMAXFREEZELOCK | 
| CM SETMAXADDRESS | 
STEEP 


SLEEP 
SMART DISABLE OPERATIONS 


(concluded) 
Table 8 describes the command behavior of drives that have been manufactured with long logical sectors. 
Data transfer commands transfer either the long logical sector length or 256 words depending on the 
command. For example, Read and Write Extended commands transfer data in long logical sectors while 
READ LOG EXT and WRITE LOG EXT commands transfer 256 words per sector, regardless of the logical 
sector length. Figure 8 example 2 shows a diagram of a device formatted with long logical sectors. 


4.23 Devices Implementing the Long Physical Sector Feature Set and the Long 
Logical Feature Sector Set 


The long physical sector feature set and the long logical sector feature set are not exclusive. Figure 8 


example 4 illustrates a device implementing both the Long Physical Sector and Long Logical Sector feature 
sets. 
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5 I/O register descriptions 


5.1 Overview 


The Command Block registers are used for sending commands to the device or posting status from the 
device. The Control Block registers are used for device control and to post alternate status. Table 9 identifies 
these registers for both devices that implement and do not implement the PACKET command feature set. 


References to parallel implementation bus signals (e.g. DMACK, DMARQ, etc) apply only to parallel 
implementations. See Volume 3 for additional information on serial protocol. Some register bits (e.g. nIEN, 
SRST, etc.) have different requirements in the serial implementation (See Volume 3). 


Table 9 - I/O registers 
Registers used by devices implementing 
PACKET command feature set PACKET command feature set 


Data Data Data Data 
Error Features Error Features 


Sector Count Sector Count Interrupt Reason Sector Count 


LBA Low LBA Low LBA Low LBA Low 

LBA Mid LBA Mid Byte Count Low Byte Count Low 

LBA High LBA High Byte Count High Byte Count High 
Device Device Device select Device select 
Status Command Status Command 


Control Block registers Control Block registers 
Alternate Status Device Control Alternate Status Device Control 


Each register description in the following Clauses contain the following format: 


Direction -specifies if the register is read/write, read only, or write only from the host. 
Access restrictions -specifies when the register may be accessed. 

Effect -specifies the effect of accessing the register. 

Functional description - describes the function of the register. 


Field/bit description - describes the content of the register. 
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5.2 Alternate Status register 

5.2.1 Direction 

This register is read only. If this address is written to by the host, the Device Control register is written. 
5.2.2 Access restrictions 


When the BSY bit is set to one, the other bits in this register shall not be used. The contents of this register 
are not valid while the device is in Sleep mode. 


5.2.3 Effect 

Reading this register shall not clear a pending interrupt. 

5.2.4 Functional description 

This register contains the same information as the Status register in the Command Block. 


See 5.14 for definitions of the bits in this register. 


5.3 Command register 

5.3.1 Direction 

This register is write only. If this address is read by the host, the Status register is read. 

5.3.2 Access restrictions 

For all commands except DEVICE RESET, this register shall only be written when BSY and DRQ are both 
cleared to zero and DMACK- is not asserted. If written when BSY or DRQ is set to one, the results of writing 
the Command register are indeterminate except for the DEVICE RESET command. For a device in the Sleep 
mode, writing of the Command register shall be ignored except for writing of the DEVICE RESET command 
to a device that implements the PACKET Command feature set. 

5.3.3 Effect 

Command processing begins when this register is written. The content of the Command Block registers 
become parameters of the command when this register is written. Writing this register clears any pending 
interrupt condition. 

5.3.4 Functional description 

This register contains the command code being sent to the device. Command execution begins immediately 
after this register is written. The executable commands and the command codes for each command are 


summarized in the tables in Annex B. 


5.3.5 Field/bit description 


ot Ge ae 2 
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5.4 Data port 

5.4.1 Direction 

This port is read/write. 

5.4.2 Access restrictions 

This port shall be accessed for host DMA data transfers only when DMACK- and DMARQ are asserted. 

5.4.3 Effect 

DMA data-out transfers are processed by a series of writes to this port, each write transferring the data that 
follows the previous write. DMA data-in transfers are processed by a series of reads to this port, each read 
transferring the data that follows the previous read. The results of a read during a DMA out or a write during 
a DMA in are indeterminate. 

5.4.4 Functional description 


The data port is 16-bits in width. 


5.4.5 Field/bit description 


pas | a Ts tas St to} 


a a (a ee ee ee eee ee 
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5.5 Data register 
5.5.1 Direction 

This register is read/write. 
5.5.2 Access restrictions 


This register shall be accessed for host PIO data transfer only when DRQ is set to one and DMACK- is not 
asserted. The contents of this register are not valid while a device is in the Sleep mode. 


5.5.3 Effect 

PIO data-out transfers are processed by a series of writes to this register, each write transferring the data 
that follows the previous write. PIO data-in transfers are processed by a series of reads to this register, each 
read transferring the data that follows the previous read. The results of a read during a PIO out or a write 
during a PIO in are indeterminate. 


5.5.4 Functional description 


The data register is 16 bits wide. When a CFA device is in 8-bit PIO data transfer mode this register is 8 bits 
wide using only DD7 to DDO. 


5.5.5 Field/bit description 


pas | aa Ts tas Sf to} 


ae a Da ee 
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5.6 Device register 

5.6.1 Direction 

This register is read/write. 

5.6.2 Access restrictions 

This register shall be written only when both BSY and DRQ are cleared to zero and DMACK- is not asserted. 
The contents of this register are valid only when BSY is cleared to zero. If this register is written when BSY 
or DRQ is set to one, the result is indeterminate. For devices not implementing the PACKET Command 
feature set, the contents of this register are not valid while a device is in the Sleep mode. For devices 
implementing the PACKET Command feature set, the contents of this register are valid while the device is in 
Sleep mode. 


5.6.3 Effect 


The DEV bit becomes effective when this register is written by the host or the signature is set by the device. 
All other bits in this register become a command parameter when the Command register is written. 


5.6.4 Functional description 


Bit 4, DEV, in this register selects the device. Other bits in this register are command dependent (See Clause 
6). 


5.6.5 Field/bit description 


a SRE EN SE ON 


Obsolete - These bits are obsolete. 


NOTE —- Some hosts set these bits to one. Devices shall ignore these bits. 


— #- The content of these bits is command dependent (See Clause 6). 
— DEV - Device select. Cleared to zero selects Device 0. Set to one selects Device 1. 
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5.7 Device Control register 

5.7.1 Direction 

This register is write only. If this address is read by the host, the Alternate Status register is read. 

5.7.2 Access restrictions 

This register shall only be written when DMACK- is not asserted. 

5.7.3 Effectiveness 

The content of this register shall take effect when written. 

5.7.4 Functional description 

This register allows a host to software reset attached devices and to enable or disable the assertion of the 
INTRQ signal by a selected device. When the Device Control register is written, both devices respond to the 
write regardless of which device is selected. When the SRST bit is set to one, both devices shall perform the 


software reset protocol. The device shall respond to the SRST bit when in the SLEEP mode. 


5.7.5 Field/bit description 


a ee ee ee eee ee ee ee ee ee 
2 AHOB [=f ae = oe ip |e SRST EN Se 0 — 1] 

— HOB (high order byte) is defined by the 48-bit Address feature set (See 4.14). A write to any 
Command Block register shall clear the HOB bit to zero. 

— Bits (6:3) are reserved. 

— SRST is the host software reset bit (See Clause 11). 

— nlEN is the enable bit for the device assertion of INTRQ to the host. When the nlEN bit is cleared to 
zero, and the device is selected, INTRQ shall be enabled through a tri-state buffer and shall be 
asserted or negated by the device as appropriate. When the nlEN bit is set to one, or the device is 
not selected, the device shall release the INTRQ signal. 

— Bit 0 shall be cleared to zero. 
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5.8 Error register 

5.8.1 Direction 

This register is read only. If this address is written to by the host, the Features register is written. 

5.8.2 Access restrictions 

The contents of this register shall be valid when BSY and DRQ are cleared to zero and either ERR or SE is 
set to one. The contents of this register shall be valid upon completion of power-on, or after a hardware or 
software reset, or after command completion of an EXECUTE DEVICE DIAGNOSTICS or DEVICE RESET 
command. The contents of this register are not valid while a device is in the Sleep mode. 

5.8.3 Effect 

None. 


5.8.4 Functional description 


At command completion of any command except EXECUTE DEVICE DIAGNOSTIC or DEVICE RESET, the 
contents of this register are valid when the ERR bit is set to one in the Status register. 


Following a power-on, a hardware or software reset (See Clause 11), or command completion of an 
EXECUTE DEVICE DIAGNOSTIC or DEVICE RESET command (See Clause 6) this register contains a 
diagnostic code. 


5.8.5 Field/bit description 


Le 
Ea Swe ae ar eee 


— Bit 2 - ABRT (command aborted) is set to one to indicate the requested command has been 
command aborted because the command code or a command parameter is invalid, the command is 
not supported, a prerequisite for the command has not been met, or some other error has occurred. 

— #-The content of this bit is command dependent (See Clause 6). 
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5.9 Features register 

5.9.1 Direction 

This register is write only. If this address is read by the host, the Error register is read. 
5.9.2 Access restrictions 


This register shall be written only when BSY and DRQ equal zero and DMACK- is not asserted. If this 
register is written when BSY or DRQ is set to one, the result is indeterminate. 


5.9.3 Effect 
The content of this register becomes a command parameter when the Command register is written. 
5.9.4 Functional description 


The content of this register is command dependent (See Clause 6). 


5.10 LBA High/Byte Count High register 

5.10.1 Direction 

This register is read/write. 

5.10.2 Access restrictions 

This register shall be written only when both BSY and DRQ are cleared to zero and DMACK- Is not asserted. 
The contents of this register are valid only when BSY and DRQ are cleared to zero. If this register is written 
when BSY or DRQ is set to one, the result is indeterminate. The contents of this register are not valid while a 
device is in the Sleep mode. 

5.10.3 Effect 

The content of this register becomes a command parameter when the Command register is written. 

5.10.4 Functional description 

The content of this register is command dependent (See Clause 6). For devices not implementing the 


PACKET command feature set, this register is called the LBA High register. For devices implementing the 
PACKET command feature set, this register is called the Byte Count High register. 
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5.11 LBA Low register 

5.11.1 Direction 

This register is read/write. 

5.11.2 Access restrictions 

This register shall be written only when both BSY and DRQ are cleared to zero and DMACK- is not asserted. 
The contents of this register are valid only when both BSY and DRQ are cleared to zero. If this register is 
written when BSY or DRQ is set to one, the result is indeterminate. The contents of this register are not valid 
while a device is in the Sleep mode. 

5.11.3 Effect 

The content of this register becomes a command parameter when the Command register is written. 


5.11.4 Functional description 


The content of this register is command dependent (See Clause 6). 


5.12 LBA Mid/Byte Count Low register 

5.12.1 Direction 

This register is read/write. 

5.12.2 Access restrictions 

This register shall be written only when both BSY and DRQ are cleared to zero and DMACK- Is not asserted. 
The contents of this register are valid only when BSY and DRQ are cleared to zero. If this register is written 
when BSY or DRQ is set to one, the result is indeterminate. The contents of this register are not valid while a 
device is in the Sleep mode. 

5.12.3 Effect 

The content of this register becomes a command parameter when the Command register is written. 

5.12.4 Functional description 

The content of this register is command dependent (See Clause 6).For devices not implementing the 


PACKET command feature set, this register is called the LBA Mid register. For devices implementing the 
PACKET command feature set, this register is called the Byte Count Low register. 
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5.13 Sector Count/Interrupt Reason register 

5.13.1 Direction 

This register is read/write. 

5.13.2 Access restrictions 

This register shall be written only when both BSY and DRQ are cleared to zero and DMACK- is not asserted. 
The contents of this register are valid only when both BSY and DRQ are cleared to zero. If this register is 
written when BSY or DRQ is set to one, the result is indeterminate. The contents of this register are not valid 
while a device is in the Sleep mode. 

5.13.3 Effect 

The content of this register becomes a command parameter when the Command register is written. 

5.13.4 Functional description 

The content of this register is command dependent (See Clause 6). For devices not implementing the 


PACKET command feature set, this register is called the Sector Count register. For devices implementing 
the PACKET command feature set, this register is called the Interrupt Reason register. 
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5.14 Status register 

5.14.1 Direction 

This register is read only. If this address is written to by the host, the Command register is written. 
5.14.2 Access restrictions 


The contents of this register, except for BSY, shall be ignored when BSY is set to one. The contents of this 
register are not valid while a device is in the Sleep mode. 


5.14.3 Effect 

Reading this register when an interrupt is pending causes the Interrupt Pending to be cleared (See Clause 
8). The host should not read the Status register when an interrupt is expected as this may clear the Interrupt 
Pending before the INTRQ can be recognized by the host. 


5.14.4 Functional description 


This register contains the device status. The contents of this register are updated to reflect the current state 
of the device. 


5.14.5 Field/bit description 


Fee aa ae a ee 


CHK 


5.14.5.1 BSY (Busy) 


BSY is set to one to indicate that the device is busy. After the host has written the Command register the 
device shall have either the BSY bit set to one, or the DRQ bit set to one, until command completion or the 
device has performed a bus release for an overlapped command. 


The BSY bit shall be set to one by the device only when one of the following events occurs: 


1) after either the negation of RESET- or the setting of the SRST bit to one in the Device 
Control register; 

2) after writing the Command register if the DRQ bit is not set to one; 

3) between blocks of a data transfer during PIO data-in commands before the DRQ bit is 
cleared to zero; 

4) after the transfer of a data block during PIO data-out commands before the DRQ bit is 
cleared to zero; 

5) during the data transfer of DMA commands either the BSY bit, the DRQ bit, or both shall 
be set to one; 

6) after the command packet is received during the execution of a PACKET command. 


NOTE —- The BSY bit may be set to one and then cleared to zero so quickly, that host 
detection of the BSY bit being set to one is not certain. 


When BSY is set to one, the device has control of the Command Block Registers and: 
1) a write to a Command Block register by the host shall cause indeterminate behavior 
except for writing DEVICE RESET command; 


2) aread from a Command Block register by the host may yield invalid contents except for 
the BSY bit itself. 
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The BSY bit shall be cleared to zero by the device: 


1) after setting DRQ to one to indicate the device is ready to transfer data; 

2) at command completion; 

3) upon releasing the bus for an overlapped command; 

4) when the device is ready to accept commands that do not require DRDY during a 
power-on, hardware or software reset. 


When BSY is cleared to zero, the host has control of the Command Block registers, the device shall: 


1) not set DRQ to one; 

2) not change ERR bit; 

3) not change the content of any other Command Block register; 

4) set the SERV bit to one when ready to continue an overlapped command that has been 
bus released. 

5) clear the DSC bit to zero when an action that uses this bit is completed. 


5.14.5.2  DRDY (Device ready) 
The DRDY bit shall be cleared to zero by the device: 


1) when power-on, hardware, or software reset or DEVICE RESET or EXECUTE DEVICE 
DIAGNOSTIC commands for devices implementing the PACKET command feature set. 


When the DRDY bit is cleared to zero, the device shall accept and attempt to execute commands as 
described in Volume 2, Clause 3. 


The DRDY bit shall be set to one by the device: 
1) when the device is capable of accepting all commands for devices not implementing the 
PACKET command feature set; 
2) prior to command completion except the DEVICE RESET or EXECUTE DEVICE 
DIAGNOSTIC command for devices implementing the PACKET command feature set. 
When the DRDY bit is set to one: 
1) the device shall accept and attempt to execute all implemented commands; 
2) devices that implement the Power Management feature set shall maintain the DRDY bit 
set to one when they are in the Idle or Standby modes. 
5.14.5.3  DFISE (Device Fault / Stream Error) 
Device Fault is implemented by many but not all commands (See Clause 6). A Device Fault is any event that 
prevents the device from completing a command that is not the result of an error described in the Error 
register. Recovery from Device Fault is device specific. See Streaming Command feature Set, (Clause 4.17) 
for description of SE bit. 
5.14.5.4 Command dependent 


The use of bits marked with # are command dependent (See Clause 6). Bit 4 was formerly the DSC (Device 
Seek Complete) bit. 
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5.14.5.5 DRQ (Data request) 
DRQ indicates that the device is ready to transfer data between the host and the device. After the host has 
written the Command register the device shall either set the BSY bit to one or the DRQ bit to one, until 
command completion or the device has performed a bus release for an overlapped command. 
The DRQ bit shall be set to one by the device: 
1) when BSY is set to one and data is ready for PIO transfer; 
2) during the data transfer of DMA commands either the BSY bit, the DRQ bit, or both shall 
be set to one. 


When the DRQ bit is set to one, the host may: 


1) transfer data via PIO mode; 
2) transfer data via DMA mode if DMARQ and DMACK- are asserted. 


The DRQ bit shall be cleared to zero by the device: 


1) when the last word of the data transfer occurs; 
2) when the last word of the command packet transfer occurs fora PACKET command. 


When the DRQ bit is cleared to zero, the host may: 


1) transfer data via DMA mode if DMARQ and DMACK- are asserted and BSY is set to 
one. 


5.14.5.6 Obsolete bits 


Some bits in this register were defined in previous ATA standards but have been declared obsolete in this 
standard. 


5.14.5.7 ERR / CHK (Error / Check) 


ERR indicates that an error occurred during execution of the previous command. For the PACKET and 
SERVICE commanas, this bit is defined as CHK and indicates that an exception condition exists (See 2.1). 


The ERR bit shall be set to one by the device: 
1) when BSY or DRQ is set to one and an error occurs in the executing command. 
When the ERR bit is set to one: 


1) the bits in the Error register shall be valid; 
2) the device shall not change the contents of the following registers until a new command 
has been accepted, the SRST bit is set to one or RESET- is asserted: 
— Error register; 
— LBA High/Mid/Low registers; 
— Sector Count register; 
— Device register. 


The ERR bit shall be cleared to zero by the device: 
1) when anew command is written to the Command register; 


2) when the SRST bit is set to one; 
3) when the RESET- signal is asserted. 
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When the ERR bit is cleared to zero at the end of a command the content of the Error register shall be 
ignored by the host. 


References to parallel implementation bus signals (e.g. DMACK, DMARQ, etc) apply only to parallel 
implementations. Some register bits (e.g. nIEN, SRST, etc.) are handled differently in the serial 
implementation (See Volume 3) 
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5.15 Signature and persistence 

5.15.1 Signature for devices not implementing the PACKET command feature set 

A device not implementing the PACKET command feature set shall place the signature in the Command 
Block registers listed below for power-on reset, hardware reset, software reset, and the EXECUTE DEVICE 


DIAGNOSTIC command. 


If the device does not implement the PACKET command feature set, the signature shall be: 


Sector Count Oih 
LBA Low Oth 
LBA Mid 0Oh 
LBA High 00h 

Device 00h 


A device implementing the PACKET command feature set shall place the signature in the Command Block 
registers listed below for power-on reset, hardware reset, software reset, the EXECUTE DEVICE 
DIAGNOSTIC command, and the DEVICE RESET command. The DEVICE RESET command shall not 
change the value of the DEV bit when writing the signature into the Device register for a device implementing 
the PACKET command feature set. If the device implements the PACKET command feature set, the 
signature is also written in the registers for the IDENTIFY DEVICE and READ SECTOR(S) commands. 


5.15.2 Signature for devices implementing the PACKET command feature set 


If the device implements the PACKET command feature set, the signature shall be: 


Interrupt Reason 01h 
LBA Low O1h 
Byte Count Low 14h 
Byte Count High EBh 
Device 000x0000b where x equals 0 except when responding to a 


DEVICE RESET, IDENTIFY DEVICE, or READ 
SECTOR(S) command. For a DEVICE RESET, IDENTIFY 
DEVICE, or READ SECTOR(S) command the value of x is 
not changed from that existing when the command is 
written to the Command register. 


If the PACKET command feature set is implemented by a device, then the signature values written by the 
device in the Command Block registers following power-on reset, hardware reset, software reset, or the 
DEVICE RESET command shall not be changed by the device until the device receives a command that sets 
DRDY to one. Writes by the host to the Command Block registers that contain the signature values shall 
overwrite the signature values and invalidate the signature. 

5.15.3 Reserved Signatures for Serial ATA Working Groups 


The following signatures are Reserved. The use of this signature is not defined by this standard. 


For a device not implementing the PACKET command feature set: 


Sector Count Oth 
LBA Low Oth 
LBA Mid 3Ch 
LBA High C3h 

Device 00h 
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For a device implementing the PACKET command feature set: 


Interrupt Reason O1ih 
LBA Low O1h 
Byte Count Low 69h 
Byte Count High 96h 
Device 000x0000b where x equals 0 except when responding to a 


DEVICE RESET, IDENTIFY DEVICE, or READ 
SECTOR(S) command. For a DEVICE RESET, IDENTIFY 
DEVICE, or READ SECTOR(S) command the value of x is 
not changed from that existing when the command is 
written to the Command register. 


5.16 Single device configurations 
5.16.1 Device 0 only configurations 


In a single device configuration where Device 0 is the only device and the host selects Device 1, Device 0 
shall respond as follows: 


1) Awrite to the Device Control register shall complete as if Device 0 was the selected device; 

2) A write to a Command Block register, other than the Command register, shall complete as if 
Device 0 was selected; 

3) Awrite to the Command register shall be ignored, except for EXECUTE DEVICE DIAGNOSTIC; 

4) If the device does not implement the PACKET Command feature set, a read of the Control Block 
or Command Block registers, other than the Status or Alternate Status registers, shall complete 
as if Device 0 was selected. A read of the Status or Alternate status register shall return the 
value OOh.; 

5) If the device implements the PACKET Command feature set, a read of the Control Block or 
Command Block registers shall return the value 0Oh. 


NOTE — Even though Device 1 is not present, the register content may appear valid for Device 1. Further 
means may be necessary to determine the existence of Device 1 (e.g., issuing a commana). 


5.16.2 Device 1 only configurations 
Host support of Device 1 only configurations is host specific. 


In a single device configuration where Device 1 is the only device and the host selects Device 0, Device 1 
shall respond to accesses of the Command Block and Control Block registers in the same way it would if 
Device 0 was present. This is because Device 1 cannot determine if Device 0 is, or is not, present. 


Host implementation of read and write operations to the Command and Control Block registers of non- 
existent Device O are host specific. 


NOTE — The remainder of this subclause is a recommendation for hosts. The host implementor 
should be aware of the following when supporting Device 1 only configurations: 


1) Following a hardware reset or software reset, the following steps may be used to reselect 
Device 1: 

a) Write to the Device register with DEV bit set to one; 

b) Using one or more of the Command Block registers that may be both written and 
read, such as the Sector Count or LBA Low, write a data pattern other than OOh or 
FFh to the register(s); 

c) Read the register(s) written in step (b). If the data read is the same as the data 
written, proceed to step (e); 

d) Repeat steps (a) to (c) until the data matches in step (c) or until 31 s has past. 
After 31 s the host may assume that Device 1 is not functioning properly; 
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e) Read the Status register and Error registers. Check the Status and Error register 
contents for any error conditions that Device 1 may have posted. 

2) Following the execution of an EXECUTE DEVICE DIAGNOSTIC command, no Interrupt 
Pending should be set to signal command completion. After writing the EXECUTE 
DEVICE DIAGNOSTIC command to the Command register, execute steps (a) to (e) as 
described in (1) above; 

3) At all other times, do not write zero into the DEV bit of the Device register. All other 
commands execute normally. 
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6 Command Descriptions 


6.1 Overview 

Commands are issued to the device by loading the required registers in the command block with the needed 
parameters and then writing the command code to the Command register. Required registers are those 
indicated by a specific content in the Inputs table for the command, i.e., not noted as na or obs. 

References to parallel implementation bus signals (e.g. DMACK, DMARQ, etc) apply only to parallel 
implementations. See Volume 3 for additional information on serial protocol. Some register bits (e.g. nlEN, 
SRST, etc.) have different requirements in the serial implementation (See Volume 3). 

Each command description in the following clauses contains the following subclauses: 

Command code -Specifies the command code for this command. 

Feature set -Specifies feature set and if the command is mandatory or optional. 


Protocol -Specifies which protocol is used by the command (See Clause 11). 


Inputs - Describes the Command Block register data that the host shall supply. 


| Register | 7] OT ST a 
eee Ne ee) ee Ss ee 
| ss SectorCount_ | | CT 
| LBALow | CT 
[SS BBA Mid ee 


i BA ighic fi a 
pS ee ee = = 


NOTE — na specifies the content of a bit or field is not applicable to the particular command. Obs specifies 
that the use of this bit is obsolete. 


Normal outputs - Describes the Command Block register data returned by the device at the end of a 
command. 


| Register | 7] | 6 | a 
[eee = a | (NOR (ed | | fae (eT RO oe 
| ss SectorCount_ | | 
2 == EBA OW SS 
pT LBAMid | 


[eae 7 (ed | (|e | 
pe ——- Devige ee EE 
eS a ry er ee ee eee ee) ee ee 


NOTE -— na indicates the content of a bit or field is not applicable to the particular command. Obs indicates 
that the use of this bit is obsolete. 


Error outputs - Describes the Command Block register data that shall be returned by the device at command 
completion with an unrecoverable error. 
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| Register | 7] | 6 | TT a 
peor = i 
p= = SectoriCount ft 
[EBA = eT 
i BN Se te 


[me a Ce (a | | Oe | 
Po Device | 
Mere ee we ee ee ee 
NOTE -— na indicates the content of a bit or field is not applicable to the particular command. Obs indicates 
that the use of this bit is obsolete. 


Prerequisites - Any prerequisite commands or conditions that shall be met before the command is issued. 


Description - The description of the command function(s). 
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6.2 CFA ERASE SECTORS 
6.2.1 Command code 

Coh 

6.2.2 Feature set 


CFA feature set. 
— If the CFA feature set is implemented this command shall be implemented. 


This command code is Vendor Specific for devices not implementing the CFA feature Set. 
6.2.3 Protocol 

Non-data (See Clause 11). 

6.2.4 Inputs 


The LBA High, LBA Mid, LBA Low, and Device registers specify the starting sector address to be erased. 
The Sector Count register specifies the number of sectors to be erased. 


| Register | 7 | 6 UT UT a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be erased. A value of OOh specifies that 256 sectors are to be erased. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA, starting LBA bits (27:24). 


6.2.5 Normal outputs 


| Register | 7] OT 6 Ta a 
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Status register 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
ERR shall be cleared to zero. 


6.2.6 Error outputs 


The device shall return command aborted if the command is not supported. An unrecoverable error 
encountered during execution of this command results in the termination of the command. The command 
block registers contain the address of the sector where the first unrecovered error occurred. 


| Register | 7] | | CT TT a CT 


LBA (23:16) 


Error Register - 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

ABRT shall be set to one if the command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

MED shall be set to one if a media error is detected. 

LBA Low, LBA Mid, LBA High, Device- 
shall be written with the address of first unrecoverable error. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

ERR shall be set to one if an Error register bit is set to one. 


6.2.7 Prerequisites 

DRDY set to one. 

6.2.8 Description 

This command pre-erases and conditions from 1 to 256 sectors as specified in the Sector Count register. 


This command should be issued in advance of a CFA WRITE SECTORS WITHOUT ERASE or a CFA 
WRITE MULTIPLE WITHOUT ERASE command to increase the execution speed of the write operation. 
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6.3 CFA REQUEST EXTENDED ERROR CODE 
6.3.1 Command code 

03h 

6.3.2 Feature set 


CFA feature set. 
— If the CFA feature set is implemented this command shall be implemented. 


6.3.3 Protocol 
Non-data (See Clause 11). 


6.3.4 Inputs 


| Register | 7] 6 OT ST 
| Features Pa 
| ss SectorCount,_ | ma 
Pp LBALow Pa 


Pp LBAMig Pa 
pe EB A ig = >= 
| Device | obs | na_—|_~cobs | DEV | ona 
| Command BH 


6.3.5 Normal outputs 


The extended error code written into the Error register is an 8-bit code. Table 10 defines these values. 


| Register | 7 |] 6 CT CT 


Error register - 
Extended error code. 
LBA Low, LBA Mid, LBA High, Device - 
May contain additional information. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
ERR shall be cleared to zero. 
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Table 10 - Extended error codes 


| _Extendederrorcode | Description 


6.3.6 Error outputs 


| Register | 7] | 6 Sa a 


na 


Error Register - 
ABRT shall be set to one if the command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
ERR shall be set to one if an Error register bit is set to one. 


6.3.7 Prerequisites 


DRDY set to one. 


Page 73 


T13/1532D Volume 1 Revision 4b 


6.3.8 Description 


This command provides an extended error code which identifies the cause of an error condition in more 
detail than is available with Status and Error register values. The CFA REQUEST EXTENDED ERROR 
CODE command shall return an extended error code if the previous command completed with an error or a 
no error detected extended error code if the previous command completed without error. 
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6.4 CFA TRANSLATE SECTOR 
6.4.1 Command code 

87h 

6.4.2 Feature set 


CFA feature set. 
— If the CFA feature set is implemented this command shall be implemented. 


This command code is Vendor Specific for devices not implementing the CFA feature Set. 
6.4.3 Protocol 
PIO data-in (See Clause 11). 


6.4.4 Inputs 


| Register | 7] OT ST a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


LBA Low - 
LBA bits (7:0). 
LBA Mid - 
LBA bits (15:8). 
LBA High - 
LBA bits (23:16). 
Device- 
the LBA bit shall be set to one to specify the address is an LBA, LBA bits (27:24). 


6.4.5 Normal outputs 


A 512 byte information table is transferred to the host. Table 11 defines these values. 


| Register | 7] OT 6 OT a Tt 


LBA Mid 


LBA High na 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
ERR shall be cleared to zero. 
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Table 11 - CFA TRANSLATE SECTOR Information 
| tC=“‘“iyte Cd Description 


6.4.6 Error outputs 


| Register | 7] | | a 
| Error S| Cnt S| ona S| ma=S| Sma =| Smna_— | ABRT | na | na _ | 
iin eee ton COUmE 2/2 a i i Ss 
Pp LBALow Pa 


Pp LBAMig Pa 
eS 
| Device | sobs | ona_{ obs | DEV | na Sd 
| Status | SY | DRDY | DF | ona | ona | ona | na _{ ERR | 


Error Register - 
ABRT shall be set to one if the command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
ERR shall be set to one if an Error register bit is set to one. 


6.4.7 Prerequisites 

DRDY set to one. 

6.4.8 Description 

This command provides information related to a specific sector. The data indicates the erased or not erased 


status of the sector, and the number of erase and write cycles performed on that sector. Devices may return 
zero in fields that do not apply or that are not supported by the device. 
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6.5 CFA WRITE MULTIPLE WITHOUT ERASE 
6.5.1 Command code 

CDh 

6.5.2 Feature set 


CFA feature set. 
— If the CFA feature set is implemented this command shall be implemented. 


6.5.3 Protocol 
PIO data-out (See Clause 11). 
6.5.4 Inputs 


The LBA Mid, LBA High, Device, and LBA Low specify the starting sector address to be written. The Sector 
Count register specifies the number of sectors to be transferred. 


| Register | 7 OT ST a fT 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device/Head - 
the LBA bit shall be set to one to specify the address is an LBA, starting LBA bits (27:24). 


6.5.5 Normal outputs 


| Register | 7] 6 UT at 


LBA Mid 


LBA High na 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
ERR shall be cleared to zero. 
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6.5.6 Error outputs 


The device shall return command aborted if the command is not supported. An unrecoverable error 
encountered during execution of this command results in the termination of the command. The command 
block registers contain the address of the sector where the first unrecovered error occurred. The amount of 
data transferred is indeterminate. 


| Register | 7] | OT a 


LBA (23:16) 
| Status | BSY | DRDY | DF | ona _ | oRQ [ na _[ _na_[ ERR | 


Error Register - 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

ABRT shall be set to one if the command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

MED shall be set to one if a media error is detected 

LBA Low, LBA Mid, LBA High, Device- 
shall be written with the address of first unrecoverable error. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.5.7 Prerequisites 


DRDY set to one. If bit 8 of IDENTIFY DEVICE data word 59 is cleared to zero, a successful SET MULTIPLE 
MODE command shall precede a CFA WRITE MULTIPLE WITHOUT ERASE command. 


6.5.8 Description 


This command is similar to the WRITE MULTIPLE command. Interrupts are not generated on every sector, 
but on the transfer of a block that contains the number of sectors defined by the SET MULTIPLE MODE. 


Command execution is identical to the WRITE MULTIPLE operation except that the sectors are written 


without an implied erase operation. The sectors should be pre-erased by a preceding CFA ERASE 
SECTORS command. 
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6.6 CFA WRITE SECTORS WITHOUT ERASE 
6.6.1 Command code 

38h 

6.6.2 Feature set 


CFA feature set. 
— If the CFA feature set is implemented this command shall be implemented. 


6.6.3 Protocol 
PIO data-out (See Clause 11). 
6.6.4 Inputs 


The LBA Mid, LBA High, Device, and LBA Low specify the starting sector address to be written. The Sector 
Count register specifies the number of sectors to be transferred. 


| Register | 7 OT ST a fT 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA, starting LBA bits (27:24). 


6.6.5 Normal outputs 


| Register | 7] 6 UT a 


LBA Mid 


LBA High na 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
ERR shall be cleared to zero. 
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6.6.6 Error outputs 


The device shall return command aborted if the command is not supported. An unrecoverable error 
encountered during execution of this command results in the termination of the command. The command 
block registers contain the address of the sector where the first unrecovered error occurred. The amount of 
data transferred is indeterminate. 


| Register | 7] OT 6 | a 


LBA (23:16) 
| Status | BSY | DRDY | DF | na_[ oRQ [ na _[ na_[ ERR | 


Error Register - 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

ABRT shall be set to one if the command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

MED shall be set to one if a media error is detected 

LBA Low, LBA Mid, LBA High, Device- 
shall be written with the address of first unrecoverable error. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.6.7 Prerequisites 

DRDY set to one. 

6.6.8 Description 

This command is similar to the WRITE SECTORS command. Command execution is identical to the WRITE 


SECTORS operation except that the sectors are written without an implied erase operation. The sectors 
should be pre-erased by a preceding CFA ERASE SECTORS command. 
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6.7 CHECK MEDIA CARD TYPE 
6.7.1 Command code 
Dih 
6.7.2 Feature set 
— Mandatory when the Media Card Pass Through Command feature set is implemented 
6.7.3 Protocol 
Non-data (See Clause 11) 


6.7.4 Inputs 


| Register | 7] OT ST a 


Features 
Sector Count 
LBA Low 


LBA Mid 
LBA High 
Device 
Command 


Feature register - 
ENB shall be set to one to enable the Media Card Pass Through Command feature set. ENB cleared 
to zero shall disable the Media Card Pass Through Command feature set. 
NOTE - Power-on, hardware, or software reset disables the Media Card Pass Through Command feature 
set. 
Device register - 
DEV shall specify the selected device. 
6.7.5 Normal Outputs 


The device shall return 55H in Sector Count register and AAH in LBA Low register. 


| Register | 7] OT a a 


Sector Count 


Card specific data 
Card specie cata 


| Device | bs, |] na_| obs | Media Type 
[status [sy orby_ [or] na [oR] 0] 0 | RR 


Sector Count register - shall contain 55H 
LBA Low register - shall contain AAH 
LBA Mid register - shall contain card-specific data 
LBA High register - shall contain card-specific data 
Device register - 
DEV shall indicate the selected device 
WP shall be set to one if the device is write protected, WP shall be cleared to zero if the device is not 
write protected. 
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Media Type shall be set as follows: 


001b SD Memory Card 
010b MMC 

011b SD IO Card 

100b Smart Media card 
000b, 101b-111b Reserved 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.7.6 Error Outputs 


If this command is not supported or there is an error in processing this command, the device shall return 
command aborted. 


| CRegister | 7] | 6 | CT a 


LBA Low na 


LBA Mid na 
a See ee Se ne | 
PC Status | BSY | DRDY | DF [| na _ [| DRQ | na_ | na_{ ERR | 


Error register - 
ABRT shall be set to one If the command is not supported or if an error occurred during the 
execution of the command. 
Device/Head register - 
DEV shall indicate the selected device 
Status register - 
ERR (BO) shall be set to 1 to indicate error occurred 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.7.7 Description 


The CHECK MEDIA CARD TYPE command allows the host to determine if the device supports the Media 
Card Pass Through Command feature set. If the ENB bit in the Features register is set to one, IDENTIFY 
DEVICE data bit 3 word 87 shall be set to one upon successful command completion. 


If the adapter supports the Media Card Pass Through Command feature set and the ENB bit of the Features 
register is set to one, the adapter shall process any further Media Card Pass Through Command feature set 
commands. If the ENB bit is cleared to zero, the adapter shall not interpret the command codes D2 through 
D4 as the Media Card Pass Through Command feature set commands. If the adapter does not support the 
Media Card Pass Through Command feature set, or the host has disabled the Media Card Pass Through 
Command feature set mode by clearing the ENB bit to zero, the host shall not send any further Media Card 
Pass Through Command feature set commands to the adapter. 
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6.8 CHECK POWER MODE 
6.8.1 Command code 
E5h 
6.8.2 Feature set 
Power Management feature set. 
— This command is mandatory for devices not implementing the PACKET Command feature set. 
— Power Management feature set is mandatory when power management is not implemented by 
the PACKET command set implemented by the device. 
— This command is mandatory when the Power Management feature set is implemented. 
6.8.3 Protocol 


Non-data command (See Clause 11). 


6.8.4 Inputs 


| Register | 7] 6 UT aT 
= 2 Beanies eS a SS 
| SectorCount_ Pm 
Pp LBALow Pa 


Pp LBAMig Pa 
(am aa ne» 
| Device | obs | na obs | DEV | ma | ma | na | na | 
pe = <@oinitniatd) —= s S  ai  G 


Device register - 
DEV shall specify the selected device. 


6.8.5 Normal outputs 


| Register | 7] | GT Sa a 
po Ero ig 
PBA Low a 


Pp LBAMig Pa 
fe = SWB AIG HS | 
| Status | BSY | DRDY [| DF | na | DRQ | ona | na_{ ERR | 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


Device register - 
DEV shall indicate the selected device. 
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Sector Count result value - 
OOh - device is in Standby mode. 
80h - device is in Idle mode. 
FFh - device is in Active mode or Idle mode. 


6.8.6 Error outputs 


The device shall return command aborted if the device does not support the Power Management feature set. 


| CRegister | 7] | 6 CT 5 CT 2 a 


| Status | BSY | DRDY [| DF | na | DRQ | 


Error register - 
ABRT shall be set to one if Power Management feature set is not supported. ABRT may be set to 
one if the device is not able to complete the action requested by the command. 


Device register - 
DEV shall indicate the selected device. 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.8.7 Prerequisites 

DRDY set to one. 

6.8.8 Description 

The CHECK POWER MODE command allows the host to determine the current power mode of the device. 


The CHECK POWER MODE command shall not cause the device to change power or affect the operation of 
the Standby timer. 
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6.9 CONFIGURE STREAM 
6.9.1 Command code 
51h 
6.9.2 Feature set 
— Mandatory if the Streaming feature set is implemented. 
6.9.3 Protocol 
Non-data (See Clause 11) 


6.9.4 Inputs 


,__Register __{| 7 | 6 | 5 [4 [| 3 [2 {1 [| 0 
Features Current Reserved Stream ID 

Previous Default CCTL (7:0) 

Sector Count | Current AU Size In Sectors (7:0) 

Previous AU Size In Sectors (15:8) 

LBA Low Current Reserved (7:0) 

Previous Reserved (31:24) 

LBA Mid Current Reserved (15:8) 


Previous Reserved (39:32) 
LBA High Current Reserved (23:16) 
Previous Reserved (47:40) 


Sih 
NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Features register current - 
A/R specifies a request to add a new stream if set to one. If cleared to zero, a request to remove a 
previous configured stream is specified. 
R/W specifies a read stream if cleared to zero and a write stream if set to one. 
The Stream ID shall be a value between 0 and 7. 
Features register previous - 
The default Command Completion Time Limit (CCTL). The value is calculated as follows: 
(Default CCTL) = ((content of the Features register) * (IDENTIFY DEVICE data 
words (99:98))) microseconds 
This time shall be used by the device when a streaming command with the same stream ID and a 
CCTL of zero is issued. The time is measured from the write of the command register to the final 
INTRQ for command completion. 
Sector Count Current - 
The size of an Allocation Unit in sectors (bits 7:0). 
Sector Count Previous - 
The size of an Allocation Unit in sectors (bits 15:8). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.9.5 Normal Outputs 


| Register | 7] dT 6 CT CUT 4A | 3 UT 2 a 
Sector Count | HOB =0 Reserved 
Reserved 
Reserved 
Reserved 
Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


LBA Low 


LBA Mid 


LBA High 


Reserved 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SE shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.9.6 Error Outputs 


| Register | 7] | 6 CT CC] A | 3 UT 2 a 


Sector Count 


LBA Low 


HOB=1 Reserved 
Reserved 
Reserved 


LBA Mid 


Reserved 
Reserved 


LBA High 


Reserved 
Reserved 


Device 


na Reserved 


Status 


DRQ 


NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
ABRT shall be set to one if: 
The drive cannot support the requested stream configuration 
A/R = 0 and the Features Register contains an unconfigured Stream ID 
The Default CCTL cannot be supported by the device 
The device does not support the Streaming Feature Set. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SE shall be cleared to zero. 
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DRQ shall be cleared to Zero. 

ERR shall be set to one. 
6.9.7 Prerequisites 
DRDY set to one and BSY cleared to zero. 
6.9.8 Description 
The CONFIGURE STREAM command specifies the operating parameters of an individual stream. A 
CONFIGURE STREAM command may be issued for each stream that is to be added or removed from the 
current operating configuration. If A/R = 1 and the specified Stream ID is already valid at the device, the new 


parameters shall replace the old parameters, unless Command Abort is returned (See ABRT conditions for 
Error register). In this case the old parameters for the specified Stream ID shall remain in effect. 
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6.10 DEVICE CONFIGURATION 


Individual Device Configuration Overlay feature set commands are identified by the value placed in the 
Features register. Table 12 shows these Features register values. 


Table 12 - Device Configuration Overlay Features register values 


Value Command 


Coh DEVICE CONFIGURATION RESTORE 


Cih DEVICE CONFIGURATION FREEZE LOCK 


C2h DEVICE CONFIGURATION IDENTIFY 
C3h DEVICE CONFIGURATION SET 
OOh-BFh, C4h-FFh Reserved 


6.10.1 DEVICE CONFIGURATION RESTORE 
6.10.1.1 Command code 

Bih with a Features register value of COh. 
6.10.1.2 Feature set 


Device Configuration Overlay feature set. 
— Mandatory when the Device Configuration Overlay feature set is implemented. 


6.10.1.3 Protocol 
Non-data (See Clause 11) 
6.10.1.4 Inputs 


The Features register shall be set to COh. 


| Register | 7] OT 6 TS a ft 


Sector Count 


LBA Low 


LBA Mid 
LBA High 


Device - 
DEV shall specify the selected device. 


6.10.1.5 Normal outputs 


| Register | 7] OT ST a 


n 


DEV na 
| Status | BSY | DRDY | DF | na | DRQ | na | na_[ ERR 
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Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to Zero. 
ERR shall be cleared to zero. 


6.10.1.6 Error outputs 


| Register | 7 | 6 | CT a 
| SectorCount, | a 


LBA Low 


LBA Mid 
LBA High 


[Device [os [na [obs er 
| Status | BSY [| DRDY [| DF | na_| ORQ | na | na | ERR | 


Error register - 

ABRT shall be set to one if the device does not support this command, if a Host Protected Area has 
been set by a SET MAX ADDRESS or SET MAX ADDRESS EXT command, or if DEVICE 
CONFIGURATION FREEZE LOCK is set. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.10.1.7 Prerequisites 

DRDY set to one. 

6.10.1.8 Description 

The DEVICE CONFIGURATION RESTORE command disables any setting previously made by a DEVICE 
CONFIGURATION SET command and returns the content of the IDENTIFY DEVICE or IDENTIFY PACKET 
DEVICE command data to the original settings as indicated by the data returned from the execution of a 
DEVICE CONFIGURATION IDENTIFY command. 

6.10.2 DEVICE CONFIGURATION FREEZE LOCK 

6.10.2.1 Command code 

Bih with a Features register value of Cih. 


6.10.2.2 Feature set 


Device Configuration Overlay feature set. 
— Mandatory when the Device Configuration Overlay feature set is implemented. 
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6.10.2.3 Protocol 
Non-data (See Clause 11) 
6.10.2.4 Inputs 


The Features register shall be set to C1h. 


| Register | 7] 6 Sa a 
| Features Pa 


Sector Count 


LBA Low 


LBA Mid 
LBA High 


Device - 
DEV shall specify the selected device. 


6.10.2.5 Normal outputs 


,_-Register | 7 je [sp | a te ef a 


LBA Low 
LBA Mid 
LBA High 


| Status | SY [ DRDY | DF | na_| 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.10.2.6 Error outputs 


| Register | 7 |] G6 | Sa a 
| Error S| Cn S| ona S| ma—S| Cma_—| Sma] ABRT | na _[ na _ | 
| ss SectorCount Pn 


LBA Low a 1” 
LBA Mid 1” 
—————————— 


LBA High 


| Status | BSY_ | DRDY [| DF | na__| DRQ 


Error register - 
ABRT shall be set to one if the device does not support this command or the device has executed a 
previous DEVICE CONFIGURATION FREEZE LOCK command since power-up. 
Device register - 
DEV shall indicate the selected device. 
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Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 
6.10.2.7 Prerequisites 
DRDY set to one. 
6.10.2.8 Description 


The DEVICE CONFIGURATION FREEZE LOCK command prevents accidental modification of the Device 
Configuration Overlay settings. After successful execution of a DEVICE CONFIGURATION FREEZE LOCK 
command, all DEVICE CONFIGURATION SET, DEVICE CONFIGURATION FREEZE LOCK, DEVICE 
CONFIGURATION IDENTIFY, and DEVICE CONFIGURATION RESTORE commands shall be aborted by 
the device. The DEVICE CONFIGURATION FREEZE LOCK condition shall be cleared by a power-down. 
The DEVICE CONFIGURATION FREEZE LOCK condition shall not be cleared by hardware or software 
reset. 


6.10.3 DEVICE CONFIGURATION IDENTIFY 
6.10.3.1 Command code 

Bih with a Features register value of C2h. 
6.10.3.2 Feature set 


Device Configuration Overlay feature set. 
— Mandatory when the Device Configuration Overlay feature set is implemented. 


6.10.3.3 Protocol 
PIO data-in (See Clause 11) 
6.10.3.4 Inputs 


The Features register shall be set to C2h. 


| Register | 7] fT 6 TS a 


Sector Count 


LBA Low 


LBA Mid 
LBA High 


Device - 
DEV shall specify the selected device. 
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6.10.3.5 Normal outputs 


| Register | 7] OT 6 Sa a 
1” 


BSY 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.10.3.6 Error outputs 


| Register | 7] | 6 CU] 5 CU] A TT 2 a 
P Error | ma | na ST nS] nk S| nat T ABRT | na | ona 
| SectorCount, Pm 
LBA Low a 
LBA Mid a 
LBA High ———————————— 
| Status | BSY_ | DRDY [| _DF_ | na_| DRQ 
Error register - 
ABRT shall be set to one if the device does not support this command or the device has executed a 
previous DEVICE CONFIGURATION FREEZE LOCK command since power-up. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 


DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.10.3.7 Prerequisites 

DRDY set to one. 

6.10.3.8 Description 

The DEVICE CONFIGURATION IDENTIFY command returns a 512 byte data structure via PIO data-in 
transfer. The content of this data structure indicates the selectable commands, modes, and feature sets that 
the device is capable of supporting. If a DEVICE CONFIGURATION SET command has been issued 
reducing the capabilities, the response to an IDENTIFY DEVICE or IDENTIFY PACKET DEVICE command 
will reflect the reduced set of capabilities, while the DEVICE CONFIGURATION IDENTIFY command will 
reflect the entire set of selectable capabilities. 


The term ‘is allowed’ indicates that the device may report that a feature is supported and/or enabled. 
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If the device is not ‘allowed’ to report support, then the device shall not support and shall report that the 
selected feature is both ‘not supported’ and if appropriate ‘not enabled.’ 


The format of the Device Configuration Overlay data structure is shown in Table 13. 


Table 13 - Device Configuration Identify data structure 


Data structure revision 
Multiword DMA modes supported 
15-3 Reserved 
2 1 = Reporting support for Multiword DMA mode 2 and below is allowed 
1 1 = Reporting support for Multiword DMA mode 1 and below is allowed 
0 1 = Reporting support for Multiword DMA mode 0 is allowed 
Ultra DMA modes supported 
15-7 Reserved 
1 = Reporting support for Ultra DMA mode 6 and below is allowed 
1 = Reporting support for Ultra DMA mode 5 and below is allowed 
1 = Reporting support for Ultra DMA mode 4 and below is allowed 
1 = Reporting support for Ultra DMA mode 3 and below is allowed 
1 = Reporting support for Ultra DMA mode 2 and below is allowed 
1 = Reporting support for Ultra DMA mode 1 and below is allowed 
1 = Reporting support for Ultra DMA mode 0 is allowed 
Maximum LBA 
Command set/feature set supported 
15-14 Reserved 
13 1 = Reporting support for SMART Conveyance self-test is allowed 
12 1 = Reporting support for SMART Selective self-test is allowed 
11 1 = Reporting support for Forced Unit Access is allowed 
10 Reserved 
9 
8 
7 
6 
5 


1 = Reporting support for Streaming feature set is allowed 
1 = Reporting support for 48-bit Addressing feature set is allowed 
1 = Reporting support for Host Protected Area feature set is allowed 
1 = Reporting support for Automatic acoustic management is allowed 
1 = Reporting support for READ/WRITE DMA QUEUED commands is 
allowed 
4 1 = Reporting support for Power-up in Standby feature set is allowed 
3 1 = Reporting support for Security feature set is allowed 
2 1 = Reporting support for SMART error log is allowed 
1 1 = Reporting support for SMART self-test is allowed 
0 1 = Reporting support for SMART feature set is allowed 
Reserved for serial ATA 
Reserved 
Integrity word 
15-8 Checksum 
7-0 Signature 


6.10.3.8.1 Word 0: Data structure revision 
Word 0 shall contain the value 0002h. 
6.10.3.8.2 Word 1: Multiword DMA modes supported 


Word 1 bits (2:0) contain the same information as contained in word 63 of the IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE command data (See 6.17.31). Bits (15:3) of word 1 are reserved. 
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6.10.3.8.3 Word 2: Ultra DMA modes supported 


Word 2 bits (6:0) contain the same information as contained in word 88 of the IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE command data (See 6.17.44). Bits (15:7) of word 2 are reserved. 


6.10.3.8.4 Words (6:3): Maximum LBA 

Words (6:3) define the maximum LBA. This is the highest address accepted by the device in the factory 
default condition. If no DEVICE CONFIGURATION SET command has been executed modifying the factory 
default condition, this is the same value as that returned by a READ NATIVE MAX ADDRESS or READ 
NATIVE MAX ADDRESS EXT command. 

6.10.3.8.5 Word 7: Command/features set supported 


Word 7 bit 0 if set to one indicates that the device is allowed to report support for the SMART feature set. 


Word 7 bit 1 if set to one indicates that the device allowed to report support for SMART self-test including the 
self-test log. 


Word 7 bit 2 if set to one indicates that the device is allowed to report support for SMART error logging. 
Word 7 bit 3 if set to one indicates that the device is allowed to report support for the Security feature set. 


Word 7 bit 4 if set to one indicates that the device is allowed to report support for the Power-up in Standby 
feature set. 


Word 7 bit 5 if set to one indicates that the device is allowed to report support for the READ DMA QUEUED 
and WRITE DMA QUEUED commands. 


Word 7 bit 6 if set to one indicates that the device is allowed to report support for the Automatic Acoustic 
Management feature set. 


Word 7 bit 7 if set to one indicates that the device is allowed to report support for the Host Protected Area 
feature set. 


Word 7 bit 8 if set to one indicates that the device is allowed to report support for the 48-bit Addressing 
feature set. 


Word 7 bit 9 if set to one indicates that the device is allowed to report support for Streaming feature set. 
Word 7 bit 10 -Reserved 


Word 7 bit 11if set to one indicates that the device is allowed to report support for Force Unit Access 
commands. 


Word 7 bit 12 if set to one indicates that the device is allowed to report support for SMART Selective self- 
test. 


Word 7 bit 13 if set to one indicates that the device is allowed to report support for SMART Conveyance 
self-test. 


6.10.3.8.6 Word 8-9: Reserved for serial ATA 
These words are reserved for future serial ATA use. 


6.10.3.8.7 Words (254:10): Reserved 
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6.10.3.8.8 Word 255: Integrity word 

Bits (7:0) of this word shall contain the value A5Sh. Bits (15:8) of this word shall contain the data structure 
checksum. The data structure checksum shall be the two’s complement of the sum of all byte in words 
(154:0) and the byte consisting of bits (7:0) of word 255. Each byte shall be added with unsigned arithmetic, 
and overflow shall be ignored. The sum of all bytes is zero when the checksum is correct. 

6.10.4 DEVICE CONFIGURATION SET 

6.10.4.1 Command code 

Bih with a Features register value of C3h. 


6.10.4.2 Feature set 


Device Configuration Overlay feature set. 
— Mandatory when the Device Configuration Overlay feature set is implemented. 


6.10.4.3 Protocol 
PIO data out (See Clause 11). 
6.10.4.4 Inputs 


The Features register shall be set to C3h. 


| Register | 7] OT 6 OT a 
| Features PBA 


Sector Count 


LBA Low 


LBA Mid 
LBA High 


Device - 
DEV shall specify the selected device. 


6.10.4.5 Normal outputs 


.__Register of 7 | 6 foe ft 4 ft fe a 


satus [sy prov |r | na DRQ 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.10.4.6 Error outputs 


| Register | 7 | 6 | a a 
Vendor specific 


Bit location high 
Word location 


na 

DRQ_| na na__| ERR 
Error register - 
ABRT shall be set to one if the device does not support this command, if a DEVICE CONFIGURATION SET 
command has already modified the original settings as reported by a DEVICE CONFIGURATION IDENTIFY 
command, if DEVICE CONFIGURATION FREEZE LOCK is set, if any of the bit modification restrictions 
described in 6.10.4.8 are violated, or if a Host Protected Area has been established by the execution of a 


SET MAX ADDRESS or SET MAX ADDRESS EXT command, or if an attempt was made to modify a mode 
or feature that cannot be modified with the device in its current state. 


Sector Count - 
This register may contain a vendor specific value. 
LBA Low - 

If the command was aborted because an attempt was made to modify a mode or feature that cannot 
be modified with the device in its current state, this register shall contain bits (7:0) set in the 
bit positions that correspond to the bits in the device configuration overlay data structure 
words 1, 2, or 7 for each mode or feature that cannot be changed. If not, the value shall be 
OOh. 

LBA Mid - 

If the command was aborted because an attempt was made to modify a mode or feature that cannot 
be modified with the device in its current state, this register shall contain bits (15:8) set in the 
bit positions that correspond to the bits in the device configuration overlay data structure 
words 1, 2, or 7 for each mode or feature that cannot be changed. If not, the value shall be 
OOh. 

LBA High - 

If the command was aborted because an attempt was made to modify a bit that cannot be modified 
with the device in its current state, this register shall contain the offset of the first word 
encountered that cannot be changed. If an illegal maximum LBA is encountered, the offset of 
word 3 shall be entered. If a checksum error occurred, the value FFh shall be entered. A 
value of 00h indicates that the Data Structure Revision was invalid. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.10.4.7 Prerequisites 

DRDY set to one. 

6.10.4.8 Description 

The DEVICE CONFIGURATION SET command allows a device manufacturer or a personal computer 
system manufacturer to reduce the set of optional commands, modes, or feature sets supported by a device 


as indicated by a DEVICE CONFIGURATION IDENTIFY command. The DEVICE CONFIGURATION SET 
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command transfers an overlay that modifies some of the bits set in words 63, 82, 83, 84, and 88 of the 
IDENTIFY DEVICE or IDENTIFY PACKET DEVICE command data. When the bits in these words are 
cleared, the device shall no longer support the indicated command, mode, or feature set. If a bit is set in the 
overlay transmitted by the device that is not set in the overlay received from a DEVICE CONFIGURATION 
IDENTIFY command, no action is taken for that bit. Modifying the maximum LBA of the device also modifies 
the address value returned by a READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT 
command. 


The format of the overlay transmitted by the device is described in Table 14. The restrictions on changing 
these bits is described in the text following Table 14. If any of the bit modification restrictions described are 
violated, the device shall return command aborted. 


The term ‘is allowed’ indicates that the device may report that a feature is supported and/or enabled. 


If the device is not ‘allowed’ to report support, then the device shall not support and shall report that the 
selected feature is both ‘not supported’ and if appropriate ‘not enabled.’ 
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Table 14 - Device Configuration Overlay data structure 


Word Content 


Data structure revision 
Multiword DMA modes supported 
15-3 Reserved 
2 1 = Reporting support for Multiword DMA mode 2 and below is allowed 
1 1 = Reporting support for Multiword DMA mode 1 and below is allowed 
0 1 = Reporting support for Multiword DMA mode 0 is allowed 
Ultra DMA modes supported 
15-7 Reserved 
1 = Reporting support for Ultra DMA mode 6 and below is allowed 
1 = Reporting support for Ultra DMA mode 5 and below is allowed 
1 = Reporting support for Ultra DMA mode 4 and below is allowed 
1 = Reporting support for Ultra DMA mode 3 and below is allowed 
1 = Reporting support for Ultra DMA mode 2 and below is allowed 
1 = Reporting support for Ultra DMA mode 1 and below is allowed 
1 = Reporting support for Ultra DMA mode 0 is allowed 
Maximum LBA 


Command set/feature set supported 
Reserved 


1 = Reporting support for SMART Conveyance self-test is allowed 
1 = Reporting support for SMART Selective self-test is allowed 
1 = Reporting support for Forced Unit Access is allowed 
-Reserved for technical report 
1 = Reporting support for Streaming feature set is allowed 
1 = Reporting support for 48-bit Addressing feature set is allowed 
1 = Reporting support for Host Protected Area feature set is allowed 
1 = Reporting support for Automatic acoustic management is allowed 
1 = Reporting support for READ/WRITE DMA QUEUED commands is 
allowed 
1 = Reporting support for Power-up in Standby feature set is allowed 
1 = Reporting support for Security feature set is allowed 
1 = Reporting support for SMART error log is allowed 
1 = Reporting support for SMART self-test is allowed 
1 = Reporting support for SMART feature set is allowed 

Reserved for serial ATA 

Reserved 

Integrity word 

15-8 Checksum 
7-0 Signature 


6.10.4.8.1 Word 0: Data structure revision 

Word 0 shall contain the value 0002h. 

6.10.4.8.2 Word 1: Multiword DMA modes supported 

Word 1 bits (15:3) are reserved. 

Word 1 bit 2 is cleared to disable support for Multiword DMA mode 2 and has the effect of clearing bit 2 in 
word 63 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be cleared to 
zero if Multiword DMA mode 2 is currently selected. 

Word 1 bit 1 is cleared to disable support for Multiword DMA mode 1 and has the effect of clearing bit 1 to 
zero in word 63 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Multiword DMA mode 2 is supported or Multiword DMA mode 1 or 2 is selected. 


Word 1 bit O shall not be cleared to zero. 
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6.10.4.8.3 Word 2: Ultra DMA modes supported 
Word 2 bits (15:7) are reserved. 


Word 2 bit 6 is cleared to zero to disable support for Ultra DMA mode 6 and has the effect of clearing bit 6 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 6 is currently selected. 


Word 2 bit 5 is cleared to zero to disable support for Ultra DMA mode 5 and has the effect of clearing bit 5 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 5 is currently selected. 


Word 2 bit 4 is cleared to zero to disable support for Ultra DMA mode 4 and has the effect of clearing bit 4 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 5 is supported or if Ultra DMA mode 5 or 4 is selected. 


Word 2 bit 3 is cleared to zero to disable support for Ultra DMA mode 3 and has the effect of clearing bit 3 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 5 or 4 is supported or if Ultra DMA mode 5, 4, or 3 is selected. 


Word 2 bit 2 is cleared to zero to disable support for Ultra DMA mode 2 and has the effect of clearing bit 2 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 5, 4, or 3 is supported or if Ultra DMA mode 5, 4, 3, or 2 is selected. 


Word 2 bit 1 is cleared to zero to disable support for Ultra DMA mode 1 and has the effect of clearing bit 1 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 5, 4, 3, or 2 is supported or if Ultra DMA mode 5, 4, 3, 2, or 1 is selected. 


Word 2 bit O is cleared to zero to disable support for Ultra DMA mode 0 and has the effect of clearing bit 0 to 
zero in word 88 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. This bit shall not be 
cleared to zero if Ultra DMA mode 5, 4, 3, 2, or 1 is supported or if Ultra DMA mode 5, 4, 3, 2, 1, or O is 
selected. 


6.10.4.8.4 Words (6:3): Maximum LBA 


Words (6:3) define the maximum LBA. This shall be the highest address accepted by the device after 
execution of the command. When this value is changed, the content of IDENTIFY DEVICE data words 
(61:60) and (103:100) shall be changed as described in the SET MAX ADDRESS and SET MAX ADDRESS 
EXT command descriptions to reflect the maximum address set with this command. This value shall not be 
changed and command aborted shall be returned if a Host Protected Area has been established by the 
execution of a SET MAX ADDRESS or SET MAX ADDRESS EXT command with an address value less than 
that returned by a READ NATIVE MAX ADDRESS or READ NATIVE MAX ADDRESS EXT command. Any 
data contained in the Host Protected Area is not affected. 


6.10.4.8.5 Word 7: Command/features set supported 
Word 7 bits (15:14) are reserved. 


Word 7 bit 13 is cleared to zero to disable support for the SMART Conveyance self-test. Subsequent 
attempts to start this test via the SMART EXECUTE OFF-LINE IMMEDIATE command shall cause that 
command to abort. In addition, the SMART READ DATA command shall clear bit 5 to zero in the “Off-line 
data collection capabilities" field. If this bit is supported by DEVICE CONFIGURATION SET, then this feature 
shall not be disabled by bit 1 of word 7. 


Word 7 bit 12 is cleared to zero to disable support for the SMART Selective self-test. Subsequent attempts to 


start this test test via the SMART EXECUTE OFF-LINE IMMEDIATE command shall cause that command to 
abort. In addition, the SMART READ DATA command shall clear bit 6 to zero in the “Off-line data collection 
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capabilities “ field. If this bit is supported by DEVICE CONFIGURATION SET, then this feature shall not be 
disabled by bit 1 of word 7. 


Word 7 bit 11 is cleared to zero to disable support for the Force Unit Access commands and has the effect of 
clearing bits 6 and 7 to zero in word 84 and word 87 of the IDENTIFY DEVICE or IDENTIFY PACKET 
DEVICE response. 


Word 7 bit 10 is -Reserved 


Word 7 bit 9 is cleared to zero to disable support for the Streaming feature set and has the effect of clearing 
bits 4, 9 and 10 to zero in word 84 and word 87 and clearing the value in words (99:95) and word 104 of the 
IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. 


Word 7 bit 8 is cleared to zero to disable support for the 48-bit Addressing feature set and has the effect of 
clearing bit 10 to zero in word 83 and word 86 and clearing the value in words (103:100) of the IDENTIFY 
DEVICE or IDENTIFY PACKET DEVICE response. 


Word 7 bit 7 is cleared to zero to disable support for the Host Protected Area feature set and has the effect of 
clearing bit 10 to zero in word 82 and word 85 and clearing bit 8 to zero in word 83 and word 86 of the 
IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. If a Host Protected Area has been established 
by use of the SET MAX ADDRESS or SET MAX ADDRESS EXT command, these bits shall not be cleared 
to zero and the device shall return command aborted. 


Word 7 bit 6 is cleared to zero to disable for the Automatic Acoustic Management feature set and has the 
effect of clearing bit 9 to zero in word 83 and word 94 of the IDENTIFY DEVICE or IDENTIFY PACKET 
DEVICE response. 


Word 7 bit 5 is cleared to zero to disable support for the READ DMA QUEUED and WRITE DMA QUEUED 
commands and has the effect of clearing bit 1 to zero in word 83 and word 86 of the IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE response. 


Word 7 bit 4 is cleared to zero to disable support for the Power-up in Standby feature set and has the effect 
of clearing bits (6:5) to zero in word 83 and word 86 and clearing the value in word 94 of the IDENTIFY 
DEVICE or IDENTIFY PACKET DEVICE response. If Power-up in Standby has been enabled by a jumper, 
these bits shall not be cleared. 


Word 7 bit 3 is cleared to zero to disable support for the Security feature set and has the effect of clearing bit 
1 to zero in word 82 and word 85 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. These 
bits shall not be cleared if the Security feature set has been enabled. 


Word 7 bit 2 is cleared to zero to disable support for the SMART error logging and has the effect of clearing 
bit 0 to zero in word 84 and word 87 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. 


Word 7 bit 1 is cleared to zero to disable support for the SMART self-test and has the effect of clearing bit 1 
to zero in word 84 and word 87 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. 
Word 7 bit 1 disables support for the offline, short , extended self-tests (off-line and captive modes). 
If bit 12 or bit 13 of word 7 are not supported, Word 7 bit 1 may also disable support for conveyance 
self-test and selective self-test. 


Word 7 bit 0 is cleared to zero to disable support for the SMART feature set and has the effect of clearing bit 
0 to zero in word 82 and word 85 of the IDENTIFY DEVICE or IDENTIFY PACKET DEVICE response. If bits 
(2:1) of word 7 are not cleared to zero or if the SMART feature set has been enabled by use of the SMART 
ENABLE OPERATIONS command, these bits shall not be cleared and the device shall return command 
aborted. 

6.10.4.8.6 Words 8-9: Reserved for serial ATA 


These words are reserved for future serial ATA use. 
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6.10.4.8.7 Words (254:10): Reserved 

6.10.4.8.8 Word 255: Integrity word 

Bits (7:0) of this word shall contain the value A5h. Bits (15:8) of this word shall contain the data structure 
checksum. The data structure checksum shall be the two’s complement of the sum of all byte in words 


(254:0) and the byte consisting of bits (7:0) of word 255. Each byte shall be added with unsigned arithmetic, 
and overflow shall be ignored. The sum of all bytes is zero when the checksum is correct. 
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6.11 DEVICE RESET 

6.11.1 Command code 

08h 

6.11.2 Feature set 

General feature set 
— Use prohibited when the PACKET Command feature set is not implemented. 
— Mandatory when the PACKET Command feature set is implemented. 

6.11.3 Protocol 


Device reset (See Clause 11). 


6.11.4 Inputs 


| Register | 7 OT ST a 


Device register - 
DEV shall specify the selected device. 


6.11.5 Normal outputs 


| Register | 7] OT ST 


signature 
p Device Oo eV oe) 
See Clause 11 


Error register - 
The diagnostic code as described in 6.13 is placed in this register. 
Sector Count, LBA Low, LBA Mid, LBA High - 
Signature (See 5.15). 
Device register - 
DEV shall indicate the selected device. 
Status register - 
See Clause 11. 


6.11.6 Error outputs 


If supported, this command shall not end in an error condition. If this command is not supported and the 
device has the BSY bit or the DRQ bit set to one when the command is written, the results of this command 
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are indeterminate. If this command is not supported and the device has the BSY bit and the DRQ bit cleared 
to zero when the command is written, the device shall respond with command aborted. 

6.11.7 Prerequisites 


This command shall be accepted when BSY or DRQ is set to one, DRDY is cleared to zero, or DMARQ is 
asserted. This command shall be accepted when in Sleep mode. 


6.11.8 Description 


The DEVICE RESET command enables the host to reset an individual device without affecting the other 
device. 
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6.12 DOWNLOAD MICROCODE 
6.12.1 Command code 
92h 
6.12.2 Feature set 
General feature set 
— Optional for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 
6.12.3 Protocol 
PIO data-out (See Clause 11). 
6.12.4 Inputs 
Bits (3:0) of the Device register shall always be cleared to zero. The LBA High and LBA Mid registers shall 


be cleared to zero. The LBA Low and Sector Count registers are used together as a 16-bit sector count 
value. The Feature register specifies the subcommand code. 


| Register | 7] 6 UT at 
© 0 | 


00h 
| Device | Sobs | na obs | DEV | O | oO | oO {| oO | 


Device register - 
DEV shall specify the selected device. 


6.12.5 Normal outputs 


| Register | 7] | 6 OT a 


LBA Mid 


LBA High 


Status 


Device register - 
DEV shall indicate the selected device. 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.12.6 Error outputs 


The device shall return command aborted if the device does not support this command or did not accept the 
microcode data. The device shall return command aborted if subcommand code is not a supported value. 


| Register | 7] | ST a a 


| Status | BSY [| DRDY | DF | na | ORQ | na | na _{ ERR | 


Error register - 

ABRT shall be set to one if the device does not support this command or did not accept the 
microcode data. ABRT may be set to one if the device is not able to complete the action 
requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.12.7 Prerequisites 
DRDY set to one. 
6.12.8 Description 


This command enables the host to alter the device’s microcode. The data transferred using the 
DOWNLOAD MICROCODE command is vendor specific. 


All transfers shall be an integer multiple of the sector size. The size of the data transfer is determined by the 
contents of the LBA Low register and the Sector Count register. The LBA Low register shall be used to 
extend the Sector Count register to create a 16-bit sector count value. The LBA Low register shall be the 
most significant eight bits and the Sector Count register shall be the least significant eight bits. A value of 
zero in both the LBA Low register and the Sector Count register shall specify no data is to be transferred. 
This allows transfer sizes from O bytes to 33,553,920 bytes, in 512 byte increments. 


The Features register shall be used to determine the effect of the DOWNLOAD MICROCODE command. 
The values for the Features register are: 


— Oth - download is for immediate, temporary use. 
— 0Q7h- save downloaded code for immediate and future use. 


Either or both values may be supported. All other values are reserved. 
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6.13 EXECUTE DEVICE DIAGNOSTIC 
6.13.1 Command code 

90h 

6.13.2 Feature set 


General feature set 
— Mandatory for all devices. 


6.13.3 Protocol 
Device diagnostic (See Clause 11). 
6.13.4 Inputs 


Only the command code (90h). All other registers shall be ignored. 


| Register | 7] OT ST a fT 


LBA Mid 
n 


LBA High 


Device register - 
DEV shall be ignored. 


6.13.5 Normal outputs 


The diagnostic code written into the Error register is an 8-bit code. Table 15 defines these values. The values 
of the bits in the Error register are not as defined in Volume 3, Clause 5. Both Device 0 and Device 1 shall 
provide these register contents. 


| Register | 7] | GT a Tt 
Diagnostic code 
Sector Count 


Status 


Error register - 
Diagnostic code. 
Sector Count, LBA Low, LBA Mid, LBA High, Device registers - 
device signature (See 5.15). 
Device register - 
DEV shall be cleared to zero. 
Status register - 
See Clause 11. 
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Table 15 - Diagnostic codes 


Code (See note 1) PF Ci escription 


When this code is in the Device 0 Error register 


NOTE - 

1 Codes other than 01h and 81h may indicate additional information about the failure(s). 

2 If Device 1 is not present, the host may see the information from Device 0 even though Device 1 is 
selected. 


6.13.6 Error outputs 

Table 15 shows the error information that is returned as a diagnostic code in the Error register. 
6.13.7 Prerequisites 

This command shall be accepted regardless of the state of DRDY. 

6.13.8 Description 


This command shall cause the devices to perform the internal diagnostic tests. Both devices, if present, shall 
execute this command regardless of which device is selected. 


If the host issues an EXECUTE DEVICE DIAGNOSTIC command while a device is in or going to a power 


management mode except Sleep, then the device shall execute the EXECUTE DEVICE DIAGNOSTIC 
sequence. 
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6.14 FLUSH CACHE 

6.14.1 Command code 

E7h 

6.14.2 Feature set 

General feature set 
— Mandatory for all devices not implementing the PACKET Command feature set. 
— Optional for devices implementing the PACKET Command feature set. 

6.14.3 Protocol 

Non-data (See Clause 11). 


6.14.4 Inputs 


| Register | 7] OT ST a 
| Features Pa 


na 


Device register - 
DEV shall specify the selected device. 


6.14.5 Normal outputs 


| Register | 7] | 6 OT a 


Bsy_ [| DRDY | DF | ona | ORQ [na _ | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.14.6 Error outputs 


An unrecoverable error encountered during execution of writing data results in the termination of the 
command and the Command Block registers contain the sector address of the sector where the first 
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unrecoverable error occurred. Subsequent FLUSH CACHE commands continue the process of flushing the 
cache starting with the first sector after the sector in error. 


| Register | 7] | ST a 


| Status | SY | DRDY | DF | na_| ORQ | na | na | ERR | 


Error register - 
ABRT may be set to one if the device is not able to complete the action requested by the command. 
LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of the first unrecoverable error. If the device supports the 48-bit 
Address feature set and the error occurred in an address greater than FFFFFFFh, the value set in 
the LBA Low, LBA Mid, and LBA High registers shall be FFh and the value set in bits (3:0) of the 
Device register shall be Fh. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 


ERR shall be set to one if an Error register bit is set to one.- 
6.14.7 Prerequisites 
DRDY set to one. 
6.14.8 Description 
This command is used by the host to request the device to flush the write cache. If there is data in the write 
cache, that data shall be written to the media. The BSY bit shall remain set to one until all data has been 
successfully written or an error occurs. 
NOTE — This command may take longer than 30 s to complete. 
6.15 FLUSH CACHE EXT 
6.15.1 Command code 
EAh 


6.15.2 Feature set 


48-bit Address feature set 
— Mandatory for all devices implementing the 48-bit Address feature. 
— Prohibited for devices implementing the PACKET Command feature set. 


6.15.3 Protocol 


Non-data (See Clause 11). 
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6.15.4 Inputs 


pRegister Cd TT a 2 
Features Current Reserved 

Previous Reserved 

Sector Count Current Reserved 

Previous Reserved 

LBA Low Current Reserved 

Previous Reserved 

LBA Mid Current Reserved 

Previous Reserved 

LBA High Current Reserved 

Previous Reserved 

NOTE — The value indicated as Current is the value most recently written to the register. The value 

indicated as Previous is the value that was in the register before the most recent write to the register. 


Device register - 
DEV shall specify the selected device. 


6.15.5 Normal outputs 


ROQIStG De = somo He te ee ek = Sa Ie ef lt 
HOB=1 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 


LBA High Reserved 
Reserved 


Reserved 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 


Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.15.6 Error outputs 
An unrecoverable error encountered while writing data results in the termination of the command and the 
Command Block registers contain the sector address of the sector where the first unrecoverable error 


occurred. Subsequent FLUSH CACHE EXT commands continue the process of flushing the cache starting 
with the first sector after the sector in error. 
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[Register | ZT 8 2 a 
Sector Count | HOB =0 Reserved 
HOB = 1 Reserved 
LBA Low HOB =0 LBA (7:0) 
HOB = 1 LBA (31:24) 
LBA Mid HOB = 0 LBA (15:8) 
HOB = 1 LBA (39:32) 
LBA High HOB =0 LBA (23:16) 
HOB = 1 LBA (47:40) 
Device na Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
ABRT shall be set to one if the device is not able to complete the action requested by the command. 
LBA Low - 
LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 
bit cleared to zero. 
LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 
HOB set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register HOB 
cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register HOB 
is set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one; however, if SE is set to one, ERR shall 
be cleared to zero. 


6.15.7 Prerequisites 

DRDY set to one. 

6.15.8 Description 

This command is used by the host to request the device to flush the write cache. If there is data in the write 
cache, that data shall be written to the madia.The BSY bit shall remain set to one until all data has been 


successfully written or an error occurs. 


NOTE — This command may take longer than 30 s to complete. 
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6.16 GET MEDIA STATUS 
6.16.1 Command code 

DAh 

6.16.2 Feature set 


Removable Media Status Notification feature set 
— Mandatory for devices implementing the Removable Media Status Notification feature set. 


Removable Media feature set 
— Optional for devices implementing the Removable Media feature set. 


6.16.3 Protocol 
Non-data (See Clause 11). 


6.16.4 Inputs 


| Register | 7] fT 6 Sa a 


LBA Mid 


LBA High na 


ee 
obs 
eh ee 


Command DAh 


Device register - 
DEV shall specify the selected device. 


6.16.5 Normal outputs 


Normal outputs are returned if Media Status Notification is disabled or if no bits are set to one in the Error 
register. 


| Register | 7] | 6 OT a 


LBA Mid 


LBA High 


Status 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.16.6 Error outputs 


If the device does not support this command, the device shall return command aborted. 


| Register | 7] 6 OT a a 


| Status | SY | DRDY | DF | na _| ORQ | na | na_{ ERR | 


Error register - 
ABRT shall be set to one if device does not support this command. ABRT may be set to one if the 
device is not able to complete the action requested by the command. 
NM (No Media) shall be set to one if no media is present in the device. This bit shall be set to one for 
each execution of GET MEDIA STATUS until media is inserted into the device. 
MCR (Media Change Request) shall be set to one if the eject button is pressed by the user and 
detected by the device. The device shall reset this bit after each execution of the GET 
MEDIA STATUS command and only set the bit again for subsequent eject button presses. 
MC (Media Change) shall be set to one when the device detects media has been inserted. The 
device shall reset this bit after each execution of the GET MEDIA STATUS command and 
only set the bit again for subsequent media insertions. 
WP (Write Protect) shall be set to one for each execution of GET MEDIA STATUS while the media is 
write protected. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.16.7 Prerequisites 
DRDY set to one. 
6.16.8 Description 


This command returns media status bits WP, MC, MCR, and NM, as defined above. When Media Status 
Notification is disabled this command returns zeros in the WP, MC, MCR, and NM bits. 
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6.17 IDENTIFY DEVICE 
6.17.1 Command code 
ECh 

6.17.2 Feature set 

General feature set 


— Mandatory for all devices. 
— Devices implementing the PACKET Command feature set (See 6.17.5.2). 


6.17.3 Protocol 
PIO data-in (See Clause 11). 


6.17.4 Inputs 


| Register | 7 OT 6 OT a 
| Features Pa 
| SectorCount, Pn 
Pp LBALow Pn 


Pp LBAMig Pa 
iS EBA ighy a | 
| Device | obs | sna _~obs | DEV | ma 
Po Command EC 


Device register - 
DEV shall specify the selected device. 


6.17.5 Outputs 


6.17.5.1 Normal outputs 


| Register | 7] | 6 OT a 
a= ea | Ee” See 
| SectorCount, Pn 
p LBA Low Pa 


fi; BAVA) fl a | 
| Device | obs, | ma_{ obs | DEV | ma [| na | na | na_| 
Bsy_[ DRDY | DF | na | bRQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.17.5.2 Outputs for PACKET Command feature set devices 

In response to this command, devices that implement the PACKET Command feature set shall post 
command aborted and place the PACKET Command feature set signature in the Command Block registers 
(See 5.15). 

6.17.6 Error outputs 

Devices not implementing the PACKET Command feature set shall not report an error. 

6.17.7 Prerequisites 

DRDY set to one. 

6.17.8 Description 

The IDENTIFY DEVICE command enables the host to receive parameter information from the device. 

Some devices may have to read the media in order to complete this command. 

When the command is issued, the device sets the BSY bit to one, prepares to transfer the 256 words of 
device identification data to the host, sets the DRQ bit to one, clears the BSY bit to zero, and asserts INTRQ 
if nIEN is cleared to zero. The host may then transfer the data by reading the Data register. 16 defines the 
arrangement and meaning of the parameter words in the buffer. All reserved bits or words shall be zero. 
Some parameters are defined as a 16-bit value. A word that is defined as a 16-bit value places the most 
significant bit of the value on signal line DD15 and the least significant bit on signal line DDO (See 3.2.9). For 
serial implementation see 3.2.10. 

Some parameters are defined as 32-bit values (e.g., words (61:60)). Such fields are transferred using two 
successive word transfers. The device shall first transfer the least significant bits, bits (15:0) of the value, on 
signal lines DD(15:0) respectively. After the least significant bits have been transferred, the most significant 


bits, bits (31:16) of the value, shall be transferred on DD(15:0) respectively (See 3.2.9). 


Some parameters are defined as a string of ACSII characters. Such fields are transferred as defined in 3.2.9. 
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Table 16 - IDENTIFY DEVICE data 
RI RSM I 


General configuration bit-significant information: 
15 0 = ATA device 

14-8 Retired 
1 = removable media device 
Obsolete 
Retired 
Response incomplete 
Retired 
Reserved 


ae ape obeolae 
| 2 | O | V_| Specificconfiguration 
| 3 {| | X [Obsolete 
p45 [| xX | Retired 

b= 6) = Xe Obsolete: = 
| 7-8 | O | V_| Reserved for assignment by the CompactFlash™ Association 
fee ale meted ee 
| 20-21 [| | Xx | Retired 
| 22 {| | X | Obsolete 
}27-46 | M_| _F | Model number (40 ASCII characters) 


80h 

00h = Reserved 

Oih-FFh = Maximum number of sectors that shall be transferred per interrupt on 
READ/WRITE MULTIPLE commands 


Capabilities 
Reserved for the IDENTIFY PACKET DEVICE command. 
13 1 = Standby timer values as specified in this standard are supported 
0 = Standby timer values shall be managed by the device 
12 Reserved for the IDENTIFY PACKET DEVICE command. 
11 1 = IORDY supported 
0 = IORDY may be supported 
10 1 = IORDY may be disabled 
1 = LBA supported 
1 = DMA supported. 
Retired 
Capabilities 
Shall be cleared to zero. 
Shall be set to one. 
Reserved. 
Obsolete 
Shall be set to one to indicate a device specific Standby timer value minimum. 


7™x<xkx<xT7x*T 


beara 

= the fields reported in word 88 are valid 

= the fields reported in word 88 are not valid 

= the fields reported in words (70:64) are valid 

= the fields reported in words (70:64) are not valid 
Obsolete 


(continued) 
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Table 16 - IDENTIFY DEVICE data (continued) 
| Word | O/M_| FIV _| Description 

Obsolete 

15-9 Reserved 

8 1 = Multiple sector setting is valid 
7-0 xxh = Current setting for number of sectors that shall be transferred per interrupt on 
R/W Multiple command 

Total number of user addressable sectors 


Reserved 
1 = Multiword DMA mode 2 is selected 
0 = Multiword DMA mode 2 is not selected 
1 = Multiword DMA mode 1 is selected 
0 = Multiword DMA mode 1 is not selected 
8 1 = Multiword DMA mode 0 is selected 
0 = Multiword DMA mode 0 is not selected 
7-3 Reserved 
2 1 = Multiword DMA mode 2 and below are supported 
1 1 = Multiword DMA mode 1 and below are supported 
0 1 = Multiword DMA mode 0 is supported 
15-8 Reserved 
7-0 PIO modes supported 
Minimum Multiword DMA transfer cycle time per word 
15-0 Cycle time in nanoseconds 
Manufacturer's recommended Multiword DMA transfer cycle time 
15-0 Cycle time in nanoseconds 
Minimum PIO transfer cycle time without flow control 
15-0 Cycle time in nanoseconds 
Minimum PIO transfer cycle time with IORDY flow control 
15-0 Cycle time in nanoseconds 


69-70 | ‘| F_ | Reserved (for future command overlap and queuing 
ie TA | | E | Reserved for the IDENTIFY PACKET DEVICE command. 


Queue depth 
we . Reserved 
Maximum queue depth - 1 


reac — ie eserventer Serial 
Major version number 
0000h or FFFFh = device does not report version 
15 Reserved 
14 Reserved for ATA/ATAPI-14 
13 Reserved for ATA/ATAPI-13 
12 Reserved for ATA/ATAPI-12 
11 Reserved for ATA/ATAPI-11 
10 Reserved for ATA/ATAPI-10 
Reserved for ATA/ATAPI-9 
Reserved for ATA/ATAPI-8 
1 = supports ATA/ATAPI-7 
1 = supports ATA/ATAPI-6 
1 = supports ATA/ATAPI-5 
1 = supports ATA/ATAPI-4 
Obsolete 
Obsolete 
Obsolete 
Reserved 


7™<xx<TAmAAAAMAANMAANNMN 


ORPNWAHUON OW O 


(continued) 
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Table 16 - IDENTIFY DEVICE data (continued) 
Hird | Oi TEN | Deseret 


Minor version number 
0000h or FFFFh = device does not report version 
0001h-FFFEh = See 6.17.41 
Command set supported. 
15 Obsolete 
14 1 = NOP command supported 
13 1 = READ BUFFER command supported 
12 1 = WRITE BUFFER command supported 
11 Obsolete 
10 1 = Host Protected Area feature set supported 
1 = DEVICE RESET command supported 
1 = SERVICE interrupt supported 
= release interrupt supported 
= look-ahead supported 
1 = write cache supported 
Shall be cleared to zero to indicate that the PACKET Command feature set is not 
supported. 
1 = mandatory Power Management feature set supported 
1 = Removable Media feature set supported 
1 = Security Mode feature set supported 
1 = SMART feature set supported 
Command sets supported. 
15 Shall be cleared to zero 
14 Shall be set to one 
13 1 = FLUSH CACHE EXT command supported 
12 1 = mandatory FLUSH CACHE command supported 
11 1 = Device Configuration Overlay feature set supported 
10 1 = 48-bit Address feature set supported 
1 = Automatic Acoustic Management feature set supported 
1 = SET MAX security extension supported 
See Address Offset Reserved Area Boot, INCITS TR27:2001 
1 = SET FEATURES subcommand required to spinup after power-up 
1 = Power-Up In Standby feature set supported 
1 = Removable Media Status Notification feature set supported 
1 = Advanced Power Management feature set supported 
1 = CFA feature set supported 
1 = READ/WRITE DMA QUEUED supported 
1 = DOWNLOAD MICROCODE command supported 
Command set/feature supported extension. 
15 Shall be cleared to zero 
14 Shall be set to one 
13 1 = IDLE IMMEDIATE with UNLOAD FEATURE supported 
12 Reserved for technical report 
11 Reserved for technical report 
10 1 = URG bit supported for WRITE STREAM DMA EXT and WRITE STREAM EXT 
1 = URG bit supported for READ STREAM DMA EXT and READ STREAM EXT 
1 = 64-bit World wide name supported 
1 = WRITE DMA QUEUED FUA EXT command supported 
1 = WRITE DMA FUA EXT and WRITE MULTIPLE FUA EXT commands supported 
1 = General Purpose Logging feature set supported 
1 = Streaming feature set supported 
1 = Media Card Pass Through Command feature set supported 
1 = Media serial number supported 
1 = SMART self-test supported 
1 = SMART error logging supported 
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Table 16 - IDENTIFY DEVICE data (continued) 
A RS 


Command set/feature enabled. 
15 Obsolete 
14 1 = NOP command enabled 
13 1 = READ BUFFER command enabled 
12 1 = WRITE BUFFER command enabled 
11 Obsolete 
10 1 = Host Protected Area feature set enabled 
1 = DEVICE RESET command enabled 
1 = SERVICE interrupt enabled 
= release interrupt enabled 
= look-ahead enabled 
1 = write cache enabled 
Shall be cleared to zero to indicate that the PACKET Command feature set is not 
supported. 
1 = Power Management feature set enabled 
1 = Removable Media feature set enabled 
1 = Security Mode feature set enabled 
1 = SMART feature set enabled 
Command set/feature enabled. 
15-14 Reserved 
1 = FLUSH CACHE EXT command supported 
1 = FLUSH CACHE command supported 
1 = Device Configuration Overlay supported 
1 = 48-bit Address features set supported 
1 = Automatic Acoustic Management feature set enabled 
1 = SET MAX security extension enabled by SET MAX SET PASSWORD 
See Address Offset Reserved Area Boot, INCITS TR27:2001 
1 = SET FEATURES subcommand required to spin-up after power-up 
1 = Power-Up In Standby feature set enabled 
1 = Removable Media Status Notification feature set enabled 
1 = Advanced Power Management feature set enabled 
1 = CFA feature set enabled 
1 = READ/WRITE DMA QUEUED command supported 
1 = DOWNLOAD MICROCODE command supported 
Command set/feature default. 
15 Shall be cleared to zero 
14 Shall be set to one 
13 1 = IDLE IMMEDIATE with UNLOAD FEATURE supported 
12 Reserved for technical report- 
11 Reserved for technical report- 
10 1 = URG bit supported for WRITE STREAM DMA EXT and WRITE STREAM EXT 
1 = URG bit supported for READ STREAM DMA EXT and READ STREAM EXT 
1 = 64 bit World wide name supported 
1 = WRITE DMA QUEUED FUA EXT command supported 
1 = WRITE DMA FUA EXT and WRITE MULTIPLE FUA EXT commands supported 
1 = General Purpose Logging feature set supported 
1 = Valid CONFIGURE STREAM command has been executed 
1 = Media Card Pass Through Command feature set enabled 
1 = Media serial number is valid 
1 = SMART self-test supported 
1 = SMART error logging supported 
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Table 16 - IDENTIFY DEVICE data (continued) 
| Word | O/M | FIV [Description 
88 O 15 Reserved 

1 = Ultra DMA mode 6 is selected 

0 = Ultra DMA mode 6 is not selected 

1 = Ultra DMA mode 5 is selected 

0 = Ultra DMA mode 5 is not selected 

1 = Ultra DMA mode 4 is selected 

0 = Ultra DMA mode 4 is not selected 

1 = Ultra DMA mode 3 is selected 

0 = Ultra DMA mode 3 is not selected 

1 = Ultra DMA mode 2 is selected 

0 = Ultra DMA mode 2 is not selected 

1 = Ultra DMA mode 1 is selected 

0 = Ultra DMA mode 1 is not selected 

1 = Ultra DMA mode 0 is selected 

0 = Ultra DMA mode 0 is not selected 

Reserved 

1 = Ultra DMA mode 6 and below are supported 
1 = Ultra DMA mode 5 and below are supported 
1 = Ultra DMA mode 4 and below are supported 
1 = Ultra DMA mode 3 and below are supported 
1 = Ultra DMA mode 2 and below are supported 
1 = Ultra DMA mode 1 and below are supported 
1 = Ultra DMA mode 0 is supported 


| 89 | © | ~F | Time required for security erase unitcompletion 
| 90 | O | F | Time required for Enhanced security erase completion 
| 91 | O | V_| Current advanced powermanagementvalue 
| 92 | O | Vv | Master Password RevisionCode 


< < < < < < <7 
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93 * Hardware reset result. The contents of bits (12:0) of this word shall change only during the 
execution of a hardware reset. 
15 Shall be cleared to zero. 
14 Shall be set to one. 
13 1 = device detected CBLID- above Vi 
O = device detected CBLID- below Vi. 
12-8 Device 1 hardware reset result. Device 0 shall clear these bits to zero. Device 1 shall 
set these bits as follows: 
12 Reserved. 
11 0 = Device 1 did not assert PDIAG-. 
1 = Device 1 asserted PDIAG-. 
10-9 These bits indicate how Device 1 determined the device number: 
00 = Reserved. 
01 = a jumper was used. 
10 = the CSEL signal was used. 
11 = some other method was used or the method is unknown. 
8 Shall be set to one. 
7-0 Device 0 hardware reset result. Device 1 shall clear these bits to zero. Device 0 shall 
set these bits as follows: 
b Reserved. 
6 0 = Device 0 does not respond when Device 1 is selected. 
1 = Device 0 responds when Device 1 is selected. 
5 0 = Device 0 did not detect the assertion of DASP-. 
1 = Device O detected the assertion of DASP-. 
0 = Device 0 did not detect the assertion of PDIAG-. 
1 = Device O detected the assertion of PDIAG-. 
0 = Device 0 failed diagnostics. 
1 = Device 0 passed diagnostics. 
These bits indicate how Device 0 determined the device number: 
00 = Reserved. 
01 = a jumper was used. 
10 = the CSEL signal was used. 
11 = some other method was used or the method is unknown. 
Shall be set to one. 
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Table 16 - IDENTIFY DEVICE information (continued) 
| Word | O/M_| FIV | Description 
94 Vv 15-8 Vendor’s recommended acoustic management value. 
eee ee 7-0 Current automatic acoustic management value. 
| 95 | | SCF | Stream Minimum Request Size 
| 96 | | «SV (| Streaming TransferTime-DMA 
| 97 | |v _| Streaming Access Latency-DMAandPIO 
| 98-99 | | F | Streaming Performance Granularity 
| 100-103 | O | V_ | Maximum user LBA for 48-bit Address featureset 


| 104 | O | V | StreamingTransferTime-PIO 
| 105 | S| F | Reserved 
Physical sector size / Logical Sector Size 

Shall be cleared to zero 

Shall be set to one 

1 = Device has multiple logical sectors per physical sector. 

1= Device Logical Sector Longer than 256 Words 

Reserved 

a logical sectors per physical sector 


NAA (3:0) 

IEEE OUI (23:12) 

IEEE OUI (11:0) 

Unique ID (35:32) 

Unique ID (31:16) 

Unique ID (15: 0) 
i215 [OE | Reserved for world wide name edanion to 128 bis] 
| 116 | O | Vv | Reservedfortechnicalreport 
[117-118 | O | F | WordsperLogicalSector 
[119-126 | | =F | Reserved 


127 Removable Media Status Notification feature set support 
15-2 Reserved 
1-0 00 = Removable Media Status Notification feature set not supported 


01 = Removable Media Status Notification feature supported 
10 = Reserved 
11 = Reserved 


128 Security status 

15-9 Reserved 
Security level 0 = High, 1 = Maximum 
Reserved 
1 = Enhanced security erase supported 
1 = Security count expired 
1 = Security frozen 
1 = Security locked 
1 = Security enabled 
1 = Security supported 
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Table 16 - IDENTIFY DEVICE data (continued) 


Ee Wo td SOIME BIW Des cristo Se 
[129-159 | | ~X_| Vendor specific 


160 CFA power mode 1 
15 Word 160 supported 
14 Reserved 
13 CFA power mode 1 is required for one or more commands implemented by the 
device 
CFA power mode 1 disabled 
Maximum current in ma 


161-175 ae Reserved for assignment by the CompactFlash™ Association 
176-205 | O | V_ | Current media serial number 
206: 254 | F _| Reserved 


Integrity word 
S B Checksum 
Signature 


Key: 

O/M = Mandatory/optional requirement. 

M = Support of the word is mandatory. 

O = Support of the word is optional. 

* = See 6.17.49. 

F/V = Fixed/variable content 

F = the content of the word is fixed and does not change. For removable media devices, these values may 
change when media is removed or changed. 

V = the contents of the word is variable and may change depending on the state of the device or the 
commands executed by the device. 

X = the content of the word may be fixed or variable. 


(concluded) 
6.17.9 Word 0: General configuration 
Devices that conform to this standard shall clear bit 15 to zero. 
If bit 7 is set to one, the device is a removable media device. 
Bit 6 is obsolete. 
If bit 2 is set to one it indicates that the content of the IDENTIFY DEVICE data is incomplete. This will occur if 
the device supports the Power-up in Standby feature set and required data is contained on the device media. 


In this case the content of at least word O and word 2 shall be valid. 


Devices supporting the CFA feature set shall place the value 848Ah in word 0. In this case, the above 
definitions for the bits in word 0 are not valid. 


6.17.10 Word 1: Obsolete 
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6.17.11 Word 2: Specific configuration. 


Word 2 shall be set as follows: 


37C8h Device requires SET FEATURES subcommand to spin-up after power-up 
|_| ns bentley DEVICE datas incomplete Gee 42) 
738Ch Device requires SET FEATURES subcommand to spin-up after power-up 
| TEN | ant bentley DEVICE datas complete (gee 413) 


power-up and IDENTIFY DEVICE data is incomplete (See 4.12). 
power-up and IDENTIFY DEVICE data is complete (See 4.12). 


All other values 


6.17.12 Word 3: Obsolete 

6.17.13 Word (5:4): Retired. 

6.17.14 Word 6: Obsolete 

6.17.15 Words (8:7): Reserved for assignment by the CompactFlash™ Association 

6.17.16 Word 9: Retired. 

6.17.17 Words (19:10): Serial number 

This field contains the serial number of the device. The contents of this field is an ASCII character string of 
twenty bytes. The device shall pad the character string with spaces (20h), if necessary, to ensure that the 
string is the proper length. The combination of Serial number (words (19:10)) and Model number (words 
(46:27)) shall be unique for a given manufacturer (See 3.2.9). 

6.17.18 Word (21:20): Retired. 

6.17.19 Word 22: Obsolete. 

6.17.20 Word (26:23): Firmware revision 

This field contains the firmware revision number of the device. The contents of this field is an ASCII 
character string of eight bytes. The device shall pad the character string with spaces (20h), if necessary, to 
ensure that the string is the proper length (See 3.2.9). 

6.17.21 Words (46:27): Model number 

This field contains the model number of the device. The contents of this field is an ASCII character string of 
forty bytes. The device shall pad the character string with spaces (20h), if necessary, to ensure that the 
string is the proper length. The combination of Serial number (words (19:10)) and Model number (words 
(46:27)) shall be unique for a given manufacturer (See 3.2.9). 

6.17.22 Word 47: READ/WRITE MULTIPLE support. 

Bits (7:0) of this word define the maximum number of sectors per block that the device supports for 
READ/WRITE MULTIPLE commands. If the serial interface is implemented, this field shall be set to 16 or 


less. 


6.17.23 Word 48: Reserved. 
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6.17.24 Word (50:49): Capabilities 

Bits (15:14) of word 49 are reserved for use in the IDENTIFY PACKET DEVICE command data. 

Bit 13 of word 49 is used to determine whether a device uses the Standby timer values as defined in this 
standard. Table 19 specifies the Standby timer values used by the device if bit 13 is set to one. If bit 13 is 
cleared to zero, the timer values shall be vendor specific. 

Bit 12 of word 49 is reserved for use in the IDENTIFY PACKET DEVICE command data. 

Bit 11 of word 49 indicates whether a device supports IORDY. If this bit is set to one, then the device 
supports IORDY operation. All devices except CFA and PCMCIA devices shall support PIO mode 3 or 
higher, shall support IORDY, and shall set this bit to one. If the serial interface is implemented, this bit shall 
be set to one. 

Bit 10 of word 49 is used to indicate a device’s ability to enable or disable the use of IORDY. If this bit is set 
to one, then the device supports the disabling of IORDY. Disabling and enabling of IORDY is accomplished 
using the SET FEATURES command. If the serial interface is implemented, this bit shall be set to one. 


Bit 9 of word 49 shall be set to one to indicate that an LBA transition is supported. 


Bits 8 of word 49 Shall be set to one to indicate that DMA is supported. For devices not implementing the 
CompactFlash feature set this bit shall be set to one. 


Bits (7:0) of word 49 are retired. 

Bit 15 of word 50 shall be cleared to Zero to indicate that the contents of word 50 are valid. 
Bit 14 of word 50 shall be set to one to indicate that the contents of word 50 are valid. 

Bits (13:2) of word 50 are reserved. 

Bit 1 of word 50 is obsolete. 


Bit O of word 50 set to one indicates that the device has a minimum Standby timer value that is device 
specific. 


6.17.25 Words (52:51): Obsolete 

6.17.26 Word 53: Field validity 

Bit O of word 53 is obsolete. 

If bit 1 of word 53 is set to one, the values reported in words (70:64) are valid. If this bit is cleared to zero, 
the values reported in words (70:64) are not valid. All devices except CFA and PCMCIA devices shall 
support PIO mode 3 or above and shall set bit 1 of word 53 to one and support the fields contained in words 
(70:64). If the serial interface is implemented, this bit shall be set to one. 

If the device supports Ultra DMA and the values reported in word 88 are valid, then bit 2 of word 53 shall be 
set to one. If the device does not support Ultra DMA and the values reported in word 88 are not valid, then 


this bit is cleared to zero. If the serial interface is implemented, this bit shall be set to one. 


6.17.27 Word (58:54): Obsolete 
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6.17.28 Word 59: Multiple sector setting 


If bit 8 is set to one, bits (7:0) reflect the number of sectors currently set to transfer on a READ/WRITE 
MULTIPLE command. This field may default to the preferred value for the device (See 6.52). 


6.17.29 Word (61:60): Total number of user addressable sectors 


This field contains a value that is one greater than the maximum user accessable logical block address (See 
4.2). The maximum value that shall be placed in this field is OFFFFFFFh. 


6.17.30 Word 62: Obsolete 

6.17.31 Word 63: Multiword DMA transfer 

Word 63 identifies the Multiword DMA transfer modes supported by the device and indicates the mode that is 
currently selected. Only one DMA mode shall be selected at any given time. If an Ultra DMA mode is 
enabled, then no Multiword DMA mode shall be enabled. If a Multiword DMA mode is enabled then no Ultra 
DMA mode shall be enabled. 

6.17.31.1 Reserved 

Bits (15:11) of word 63 are reserved. 

6.17.31.2 Multiword DMA mode 2 selected 

If bit 10 of word 63 is set to one, then Multiword DMA mode 2 is selected. If this bit is cleared to zero, then 
Multiword DMA mode 2 is not selected. If bit 9 is set to one or if bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.31.3 Multiword DMA mode 1 selected 

If bit 9 of word 63 is set to one, then Multiword DMA mode 1 is selected. If this bit is cleared to zero then 
Multiword DMA mode 1 is not selected. If bit 10 is set to one or if bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.31.4 Multiword DMA mode 0 selected 

If bit 8 of word 63 is set to one, then Multiword DMA mode 0 is selected. If this bit is cleared to zero then 
Multiword DMA mode 0 is not selected. If bit 10 is set to one or if bit 9 is set to one, then this bit shall be 
cleared to zero. 

6.17.31.5 Reserved 

Bits (7:3) of word 63 are reserved. 

6.17.31.6 Multiword DMA mode 2 supported 

If bit 2 of word 63 is set to one, then Multiword DMA modes 2 and below are supported. If this bit is cleared 
to zero, then Multiword DMA mode 2 is not supported. If Multiword DMA mode 2 is supported, then 


Multiword DMA modes 1 and 0 shall also be supported. If this bit is set to one, bits (1:0) shall be set to one. If 
the serial interface is implemented, this bit shall be set to one. 
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6.17.31.7 Multiword DMA mode 1 supported 


If bit 1 of word 63 is set to one, then Multiword DMA modes 1 and below are supported. If this bit is cleared 
to zero, then Multiword DMA mode 1 is not supported. If Multiword DMA mode 1 is supported, then 
Multiword DMA mode 0 shall also be supported. If this bit is set to one, bit 0 shall be set to one. If the serial 
interface is implemented, this bit shall be set to one. 


6.17.31.8 Multiword DMA mode 0 supported 


If bit O of word 63 is set to one, then Multiword DMA mode 0 is supported. If the serial interface is 
implemented, this bit shall be set to one. 


6.17.32 Word 64: PIO transfer modes supported 


Bits (7:0) of word 64 of the IDENTIFY DEVICE data is defined as the PIO data and register transfer 
supported field. If this field is supported, bit 1 of word 53 shall be set to one. This field is bit significant. Any 
number of bits may be set to one in this field by the device to indicate the PIO modes the device is capable 
of supporting. 


Of these bits, bits (7:2) are Reserved for future PIO modes. Bit O, if set to one, indicates that the device 
supports PIO mode 3. All devices except CFA and PCMCIA devices shall support PIO mode 3 and shall set 
bit O to one. Bit 1, if set to one, indicates that the device supports PIO mode 4. If the serial interface is 
implemented, bits (1:0) shall be set to one. 


6.17.33 Word 65: Minimum Multiword DMA transfer cycle time per word 


Word 65 of the parameter information of the IDENTIFY DEVICE command data is defined as the minimum 
Multiword DMA transfer cycle time per word. This field defines, in nanoseconds, the minimum cycle time that 
the device supports when performing Multiword DMA transfers on a per word basis. If the serial interface is 
implemented, this value shall be set to indicate 120 ns. 


If this field is supported, bit 1 of word 53 shall be set to one. Any device that supports Multiword DMA mode 
1 or above shall support this field, and the value in word 65 shall not be less than the minimum cycle time for 
the fastest DMA mode supported by the device. 


If bit 1 of word 53 is set to one because a device supports a field in words (70:64) other than this field and 
the device does not support this field, the device shall return a value of zero in this field. 


6.17.34 Word 66: Device recommended Multiword DMA cycle time 


Word 66 of the parameter information of the IDENTIFY DEVICE command data is defined as the device 
recommended Multiword DMA transfer cycle time. This field defines, in nanoseconds, the minimum cycle 
time per word during a single sector host transfer while performing a multiple sector READ DMA or WRITE 
DMA command for any location on the media under nominal conditions. If a host runs at a faster cycle rate 
by operating at a cycle time of less than this value, the device may negate DMARQ for flow control. The rate 
at which DMARQ is negated could result in reduced throughput despite the faster cycle rate. Transfer at this 
rate does not ensure that flow control will not be used, but implies that higher performance may result. If the 
serial interface is implemented, this value shall be set to indicate 120 ns. 


If this field is supported, bit 1 of word 53 shall be set to one. Any device that supports Multiword DMA mode 
1 or above shall support this field, and the value in word 66 shall not be less than the value in word 65. 


If bit 1 of word 53 is set to one because a device supports a field in words (70:64) other than this field and 
the device does not support this field, the device shall return a value of zero in this field. 
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6.17.35 Word 67: Minimum PIO transfer cycle time without IORDY flow control 


Word 67 of the parameter information of the IDENTIFY DEVICE command data is defined as the minimum 
PIO transfer without IORDY flow control cycle time. This field defines, in nanoseconds, the minimum cycle 
time that, if used by the host, the device guarantees data integrity during the transfer without utilization of 
IORDY flow control. If the serial interface is implemented, this value shall be set to indicate 120 ns. 


If this field is supported, Bit 1 of word 53 shall be set to one. 


Any device that supports PIO mode 3 or above shall support this field, and the value in word 67 shall not be 
less than the value reported in word 68. 


If bit 1 of word 53 is set to one because a device supports a field in words (70:64) other than this field and 
the device does not support this field, the device shall return a value of zero in this field. 


6.17.36 Word 68: Minimum PIO transfer cycle time with IORDY flow control 


Word 68 of the parameter information of the IDENTIFY DEVICE command data is defined as the minimum 
PIO transfer with IORDY flow control cycle time. This field defines, in nanoseconds, the minimum cycle time 
that the device supports while performing data transfers while utilizing IORDY flow control. If the serial 
interface is implemented, this value shall be set to indicate 120 ns. 


If this field is supported, Bit 1 of word 53 shall be set to one. 


All devices except CFA and PCMCIA devices shall support PIO mode 3 and shall support this field, and the 
value in word 68 shall be the fastest defined PIO mode supported by the device. The maximum value 
reported in this field shall be 180 to indicate support for PIO mode 3 or above. 


If bit 1 of word 53 is set to one because a device supports a field in words (70:64) other than this field and 
the device does not support this field, the device shall return a value of zero in this field. 


6.17.37 Words (74:69): Reserved 
6.17.38 Word 75: Queue depth 


Bits (4:0) of word 75 indicate the maximum queue depth supported by the device. The queue depth includes 
all commands for which command acceptance has occurred and command completion has not occurred. 
The value in this field equals (maximum queue depth - 1), e.g., a value of zero indicates a queue depth of 
one, a value of 31 indicates a queue depth of 32. If bit 1 of word 83 is cleared to zero indicating that the 
device does not support READ/WRITE DMA QUEUED commands, the value in this field shall be zero. A 
device may support READ/WRITE DMA QUEUED commands to provide overlap only (i.e., queuing not 
supported), in this case, bit 1 of word 83 shall be set to one and the queue depth shall be set to zero. 
Support of this word is mandatory if the Queuing feature set is supported. 


6.17.39 Words (79:76): Reserved for Serial ATA 

6.17.40 Word 80: Major version number 

If not O0OOh or FFFFh, the device claims compliance with the major version(s) as indicated by bits (6:3) 
being set to one. Values other than O0000h and FFFFh are bit significant. Since ATA standards maintain 
downward compatibility, a device may set more than one bit. 

6.17.41 Word 81: Minor version number 

If an implementor claims that the revision of the standard they used to guide their implementation does not 


need to be reported or if the implementation was based upon a standard prior to the ATA-3 standard, word 
81 shall be O000h or FFFFh. 
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Table 17 defines the value that may optionally be reported in word 81 to indicate the revision of the standard 
that guided the implementation. 


Table 17 - Minor version number 


0009h 


0018h ATA/ATAPI-6 T13 1410D revision 0 
0019h ATA/ATAPI-6 T13 1410D revision 3a 


[Reserved 


0017h ATA/ATAPI-4 T13 1153D revision 17 


0023h-FFFFh Reserved 


6.17.42 Words (84:82): Features/command sets supported 

Words (84:82) shall indicate features/command sets supported. If a defined bit is cleared to zero, the 
indicated features/command set is not supported. If bit 14 of word 83 is set to one and bit 15 of word 83 is 
cleared to zero, the contents of words (83:82) contain valid support information. If not, support information is 
not valid in these words. If bit 14 of word 84 is set to one and bit 15 of word 84 is cleared to zero, the 
contents of word 84 contains valid support information. If not, support information is not valid in this word. 

If bit O of word 82 is set to one, the SMART feature set is Supported. 

If bit 1 of word 82 is set to one, the Security Mode feature set is supported. 


If bit 2 of word 82 is set to one, the Removable Media feature set is supported. 


Bit 3 of word 82 shall be set to one indicating the mandatory Power Management feature set is supported. 
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Bit 4 of word 82 shall be cleared to zero to indicate that the PACKET Command feature set is not supported. 
If bit 5 of word 82 is set to one, write cache is supported. 

If bit 6 of word 82 is set to one, look-ahead is supported. 

If bit 7 of word 82 is set to one, release interrupt is supported. 

If bit 8 of word 82 is set to one, SERVICE interrupt is supported. 

If bit 9 of word 82 is set to one, the DEVICE RESET command is supported. 

If bit 10 of word 82 is set to one, the Host Protected Area feature set is supported. 

Bit 11 of word 82 is obsolete. 

If bit 12 of word 82 is set to one, the device supports the WRITE BUFFER command. 

If bit 13 of word 82 is set to one, the device supports the READ BUFFER command. 

If bit 14 of word 82 is set to one, the device supports the NOP command. 

Bit 15 of word 82 is obsolete. 

If bit O of word 83 is set to one, the device supports the DOWNLOAD MICROCODE command. 


If bit 1 of word 83 is set to one, the device supports the READ DMA QUEUED and WRITE DMA QUEUED 
commands. 


If bit 2 of word 83 is set to one, the device supports the CFA feature set. 

If bit 3 of word 83 is set to one, the device supports the Advanced Power Management feature set. 
If bit 4 of word 83 is set to one, the device supports the Removable Media Status feature set. 

If bit 5 of word 83 is set to one, the device supports the Power-Up In Standby feature set. 


If bit 6 of word 83 is set to one, the device requires the SET FEATURES subcommand to spin-up after 
power-up if the Power-Up In Standby feature set is enabled (See 6.49.15). 


Bit 7 is defined in Address Offset Reserved Area Boot, INCITS TR27:2001. 

If bit 8 of word 83 is set to one, the device supports the SET MAX security extension. 

If bit 9 of word 83 is set to one, the device supports the Automatic Acoustic Management feature set. 
If bit 10 of word 83 is set to one, the 48-bit Address feature set is supported. 

If bit 11 of word 83 is set to one, the device supports the Device Configuration Overlay feature set. 


Bit 12 of word 83 shall be set to one indicating the device supports the mandatory FLUSH CACHE 
command. 


If bit 13 of word 83 is set to one, the device supports the FLUSH CACHE EXT command. 


If bit O of word 84 is set to one, the device supports SMART error logging. 
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If bit 1 of word 84 is set to one, the device supports SMART self-test. 

If bit 2 of word 84 is set to one, the device supports the media serial number field words (205:176). 

If bit 3 of word 84 is set to one, the device supports the Media Card Pass Through Command feature set. 
If bit 4 of word 84 is set to one, the device supports the Streaming feature set. 

If bit 5 of word 84 is set to one, the device supports the General Purpose Logging feature set. 


If bit 6 of word 84 is set to one, the device supports the WRITE DMA FUA EXT and WRITE MULTIPLE FUA 
EXT commands. 


If bit 7 of word 84 is set to one, the device supports the WRITE DMA QUEUED FUA EXT command. 
If bit 8 of word 84 is set to one, the device supports a world wide name. 


If bit 9 of word 84 is set to one, the device supports the URG bit for READ STREAM DMA EXT and READ 
STREAM EXT commands. 


If bit 10 of word 84 is set to one, the device supports the URG bit for WRITE STREAM DMA EXT and WRITE 
STREAM EXTcommands. 


Bit 11 of word 84 is reserved for technical report- 

Bit 12 of word 84 is reserved for technical report- 

If bit 13 of word 84 is set to one, the device supports IDLE IMMEDIATE with UNLOAD FEATURE. 

6.17.43 Words (87:85): Features/command sets enabled 

Words (87:85) shall indicate features/command sets enabled. If a defined bit is cleared to zero, the indicated 
features/command set is not enabled. If a supported features/command set is supported and cannot be 
disabled, it is defined as supported and the bit shall be set to one. If bit 14 of word 87 is set to one and bit 15 
of word 87 is cleared to zero, the contents of words (87:85) contain valid information. If not, information is not 
valid in these words. 

If bit O of word 85 is set to one, the SMART feature set has been enabled via the SMART ENABLE 
OPERATIONS commana. If bit 0 of word 85 is cleared to zero, the SMART feature set has been disabled via 
the SMART DISABLE OPERATIONS command. 

If bit 1 of word 85 is set to one, the Security Mode feature set has been enabled via the SECURITY SET 
PASSWORD command. If bit 1 of word 85 is cleared to zero, the Security Mode feature set has been 
disabled via the SECURITY DISABLE PASSWORD command. 

If bit 2 of word 85 is set to one, the Removable Media feature set is supported. 

Bit 3 of word 85 shall be set to one indicating the mandatory Power Management feature set is supported. 

Bit 4 of word 85 shall be cleared to zero to indicate that the PACKET Command feature set is not supported. 
If bit 5 of word 85 is set to one, write cache has been enabled via the SET FEATURES command (See 
6.49.10). If bit 5 of word 85 is cleared to zero, write cache has been disabled via the SET FEATURES 
command. 

If bit 6 of word 85 is set to one, look-ahead has been enabled via the SET FEATURES command (See 


6.49.19). If bit 6 of word 85 is cleared to zero, look-ahead has been disabled via the SET FEATURES 
command. 
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If bit 7 of word 85 is set to one, release interrupt has been enabled via the SET FEATURES command (See 
6.49.20). If bit 7 of word 85 is cleared to zero, release interrupt has been disabled via the SET FEATURES 
command. 

If bit 8 of word 85 is set to one, SERVICE interrupt has been enabled via the SET FEATURES command 
(See 6.49.21). If bit 8 of word 85 is cleared to zero, SERVICE interrupt has been disabled via the SET 
FEATURES command. 

If bit 9 of word 85 is set to one, the DEVICE RESET command is supported. 

If bit 10 of word 85 is set to one, the Host Protected Area feature set is supported. 

Bit 11 of word 85 is obsolete. 

If bit 12 of word 85 is set to one, the device supports the WRITE BUFFER command. 

If bit 13 of word 85 is set to one, the device supports the READ BUFFER command. 

If bit 14 of word 85 is set to one, the device supports the NOP command. 

Bit 15 of word 85 is obsolete. 

If bit O of word 86 is set to one, the device supports the DOWNLOAD MICROCODE command. 


If bit 1 of word 86 is set to one, the device supports the READ DMA QUEUED and WRITE DMA QUEUED 
commands. 


If bit 2 of word 86 is set to one, the device supports the CFA feature set. 

If bit 3 of word 86 is set to one, the Advanced Power Management feature set has been enabled via the SET 
FEATURES command. If bit 3 of word 86 is cleared to zero, the Advanced Power Management feature set 
has been disabled via the SET FEATURES command. 

If bit 4 of word 86 is set to one, the Removable Media Status feature set has been enabled via the SET 
FEATURES commana. If bit 4 of word 86 is cleared to zero, the Removable Media Status feature set has 
been disabled via the SET FEATURES command. 

If bit 5 of word 86 is set to one, the Power-Up In Standby feature set has been enabled via the SET 
FEATURES command (See 6.49.13). If bit 5 of word 86 is cleared to zero, the Power-Up In Standby feature 
set has been disabled via the SET FEATURES command 


If bit 6 of word 86 is set to one, the device requires the SET FEATURES subcommand to spin-up after 
power-up (See 6.49.15). 


Bit 7 of word 86 is defined in Address Offset Reserved Area Boot, INCITS TR27:2001. 


If bit 8 of word 86 is set to one, the device has had the SET MAX security extension enabled via a SET MAX 
SET PASSWORD command. 


If bit 9 of word 86 is set to one, the device has had the Automatic Acoustic Management feature set enabled 
via a SET FEATURES command and the value in word 94 is valid. 


If bit 10 of word 86 is set to one, the 48-bit Address feature set is supported. 


If bit 11 of word 86 is set to one, the device supports the Device Configuration Overlay feature set. 
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Bit 12 of word 86 shall be set to oneindicating the device supports the mandatory FLUSH CACHE 
command. 

If bit 13 of word 86 is set to one, the device supports the FLUSH CACHE EXT command. 

If bit O of word 87 is set to one, the device supports SMART error logging. 

If bit 1 of word 87 is set to one, the device supports SMART self-test. 


If bit 2 of word 87 is set to one, the media serial number field in words (205:176) is valid. This bit shall be 
cleared to zero if the media does not contain a valid serial number or if no media is present. 


If bit 3 of word 87 is set to one, the Media Card Pass Through feature set has been enabled. 
If bit 4 of word 87 is set to one, a valid CONFIGURE STREAM command has been executed. 
If bit 5 of word 87 is set to one, the device supports the General Purpose Logging feature set. 


If bit 6 of word 87 is set to one, the device supports the WRITE DMA FUA EXT and WRITE MULTIPLE FUA 
EXT commands. 


If bit 7 of word 87 is set to one, the device supports the WRITE DMA QUEUED FUA EXT command. 
If bit 8 of word 87 is set to one, the device supports a world wide name. 


If bit 9 of word 87 is set to one, the device supports the URG bit for READ STREAM DMA EXT and READ 
STREAM EXT commands. 


If bit 10 of word 87 is set to one, the device supports the URG bit for WRITE STREAM DMA EXT and WRITE 
STREAM EXT commands. 


Bit 11 of word 87 is reserved for technical report. 

Bit 12 of word 87 is reserved for technical report. 

If bit 13 of word 87 is set to one, the device supports IDLE IMMEDIATE with UNLOAD FEATURE. 

6.17.44 Word 88: Ultra DMA modes 

Word 88 identifies the Ultra DMA transfer modes supported by the device and indicates the mode that is 
currently selected. Only one DMA mode shall be selected at any given time. If an Ultra DMA mode is 
selected, then no Multiword DMA mode shall be selected. If a Multiword DMA mode is selected, then no 
Ultra DMA mode shall be selected. Support of this word is mandatory if Ultra DMA is supported. 

6.17.44.1 Reserved 

Bit (15) of word 88 is reserved. 

6.17.44.2 Ultra DMA mode 6 selected 

If bit 14 of word 88 is set to one, then Ultra DMA mode 6 is selected. If this bit is cleared to zero, then Ultra 


DMA mode 6 is not selected. If bit 13 or bit 12 or bit 11 or bit 10 or bit 9 or bit 8 is set to one, then this bit 
shall be cleared to zero. 
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6.17.44.3 Ultra DMA mode 5 selected 

If bit 13 of word 88 is set to one, then Ultra DMA mode 5 is selected. If this bit is cleared to zero, then Ultra 
DMA mode 5 is not selected. If bit 12 or bit 11 or bit 10 or bit 9 or bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.44.4 Ultra DMA mode 4 selected 

If bit 12 of word 88 is set to one, then Ultra DMA mode 4 is selected. If this bit is cleared to zero, then Ultra 
DMA mode 4 is not selected. If bit 13 or 11 or bit 10 or bit 9 or bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.44.5 Ultra DMA mode 3 selected 

If bit 11 of word 88 is set to one, then Ultra DMA mode 3 is selected. If this bit is cleared to zero, then Ultra 
DMA mode 3 is not selected. If bit 13 or 12 or bit 10 or bit 9 or bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.44.6 Ultra DMA mode 2 selected 

If bit 10 of word 88 is set to one, then Ultra DMA mode 2 is selected. If this bit is cleared to zero, then Ultra 
DMA mode 2 is not selected. If bit 13 or 12 or bit 11 or bit 9 or bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.44.7 Ultra DMA mode 1 selected 

If bit 9 of word 88 is set to one, then Ultra DMA mode 1 is selected. If this bit is cleared to zero then Ultra 
DMA mode 1 is not selected. If bit 13 or 12 or bit 11 or bit 10 or bit 8 is set to one, then this bit shall be 
cleared to zero. 

6.17.44.8 Ultra DMA mode 0 selected 

If bit 8 of word 88 is set to one, then Ultra DMA mode 0 is selected. If this bit is cleared to zero then Ultra 
DMA mode 0 is not selected. If bit 13 or 12 or bit 11 or bit 10 or bit 9 is set to one, then this bit shall be 
cleared to zero. 

6.17.44.9 Reserved 

Bit (7) of word 88 are reserved. 

6.17.44.10 Ultra DMA mode 6 supported 

If bit 6 of word 88 is set to one, then Ultra DMA modes 6 and below are supported. If this bit is cleared to 
zero, then Ultra DMA mode 6 is not supported. If Ultra DMA mode 6 is supported, then Ultra DMA modes 5, 
4, 3, 2, 1 and 0 shall also be supported. If this bit is set to one, then bits (5:0) shall be set to one. If the serial 
interface is implemented, this bit shall be set to one. 

6.17.44.11 Ultra DMA mode 5 supported 

If bit 5 of word 88 is set to one, then Ultra DMA modes 5 and below are supported. If this bit is cleared to 
zero, then Ultra DMA mode 5 is not supported. If Ultra DMA mode 5 is supported, then Ultra DMA modes 4, 
3, 2, 1 and O shall also be supported. If this bit is set to one, then bits (4:0) shall be set to one. If the serial 
interface is implemented, this bit shall be set to one. 

6.17.44.12 Ultra DMA mode 4 supported 

If bit 4 of word 88 is set to one, then Ultra DMA modes 4 and below are supported. If this bit is cleared to 


zero, then Ultra DMA mode 4 is not supported. If Ultra DMA mode 4 is supported, then Ultra DMA modes 3, 
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2, 1 and O shall also be supported. If this bit is set to one, then bits (3:0) shall be set to one. If the serial 
interface is implemented, this bit shall be set to one. 


6.17.44.13 Ultra DMA mode 3 supported 


If bit 3 of word 88 is set to one, then Ultra DMA modes 3 and below are supported. If this bit is cleared to 
zero, then Ultra DMA mode 3 is not supported. If Ultra DMA mode 3 is supported, then Ultra DMA modes 2, 
1 and O shall also be supported. If this bit is set to one, then bits (2:0) shall be set to one. If the serial 
interface is implemented, this bit shall be set to one. 


6.17.44.14 Ultra DMA mode 2 supported 

If bit 2 of word 88 is set to one, then Ultra DMA modes 2 and below are supported. If this bit is cleared to 
zero, then Ultra DMA mode 2 is not supported. If Ultra DMA mode 2 is supported, then Ultra DMA modes 1 
and 0 shall also be supported. If this bit is set to one, bits (1:0) shall be set to one. If the serial interface is 
implemented, this bit shall be set to one. 

6.17.44.15 Ultra DMA mode 1 supported 

If bit 1 of word 88 is set to one, then Ultra DMA modes 1 and below are supported. If this bit is cleared to 
zero, then Ultra DMA mode 1 is not supported. If Ultra DMA mode 1 is supported, then Ultra DMA mode 0 
shall also be supported. If this bit is set to one, bit O shall be set to one. If the serial interface is implemented, 
this bit shall be set to one. 


6.17.44.16 Ultra DMA mode 0 supported 


If bit O of word 88 is set to one, then Ultra DMA mode 0 is supported. If this bit is cleared to zero, then Ultra 
DMA is not supported. If the serial interface is implemented, this bit shall be set to one. 


6.17.45 Word 89: Time required for Security erase unit completion 


Word 89 specifies the time required for the SECURITY ERASE UNIT command to complete. Support of this 
word is mandatory if the Security feature set is supported. 


| 0 | Value not specified 


1-254 (Value*2) minutes 


6.17.46 Word 90: Time required for Enhanced security erase unit completion 


Word 90 specifies the time required for the ENHANCED SECURITY ERASE UNIT command to complete. 
Support of this word is mandatory if support of the Enhanced Security feature set is supported. 


| 0 | Value not specified 


1-254 (Value*2) minutes 


6.17.47 Word 91: Advanced power management level value 


Bits (7:0) of word 91 contain the current Advanced Power Management level setting. Support of this word is 
mandatory if advanced power management is supported. 
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6.17.48 Word 92: Master Password Revision Code 


Word 92 contains the value of the Master Password Revision Code set when the Master Password was last 
changed. Valid values are 0001h through FFFEh. A value of 0000h or FFFFh indicates that the Master 
Password Revision is not supported. Support of this word is mandatory if the Security feature set is 
supported. 


6.17.49 Word 93: Hardware configuration test results 


If bit 14 of word 93 is set to one and bit 15 of word 93 is cleared to zero, the content of word 93 contains valid 
information. During hardware reset execution, Device 0 shall clear bits (12:8) of this word to zero and shall 
set bits (7:0) of the word as indicated to show the result of the hardware reset execution. During hardware 
reset execution, Device 1 shall clear bits (7:0) of this word to zero and shall set bits (12:8) as indicated to 
show the result of the hardware reset execution. Support of bits (15:13) are mandatory. Support of bits (12:0) 
is optional. 


Bit 13 shall be set or cleared by the selected device to indicate whether the device detected CBLID- above 
Vin or below V,_ at any time during execution of each IDENTIFY DEVICE routine after receiving the 
command from the host but before returning data to the host. This test may be repeated as desired by the 
device during command execution (See Volume 2, annex A). 


If the serial interface is implemented, word 93 shall be set to the value O00Oh. 
6.17.50 Word 94: Current automatic acoustic management value 


Bits (15:8) contain the device vendor’s recommended acoustic management level (See Table 44 for an 
enumeration of all of the possible acoustic management levels). If the host desires the drive to perform with 
highest performance, it should set the automatic acoustic management level to Feh. If the OEM host desires 
the vendor’s recommended acoustic management level as defined by the device’s vendor, the host should 
set the automatic acoustic management level to the value returned to the host in these 8 bits of the 
IDENTIFY DEVICE data. The use of this setting may not provide the lowest acoustics, or the best tradeoff of 
acoustics and performance, in all configurations. Support of this word is mandatory if the Acoustic 
Management feature set is supported. 


Bits (7:0) contain the current automatic acoustic management level. If the Automatic Acoustic Management 
feature set is supported by the device, but the level has not been set by the host, this byte shall contain the 
drive’s default setting. If the Automatic Acoustic Management feature set is not supported by the device, the 
value of this byte shall be zero. 


6.17.51 Word 95: Stream Minimum Request Size 


Number of sectors that provides optimum performance in a streaming environment. This number shall be a 
power of two, with a minimum of eight sectors (4096 bytes). The starting LBA value for each streaming 
command should be evenly divisible by this request size. 


6.17.52 Word 96: Streaming Transfer Time -- DMA 


Word 96 defines the Streaming Transfer Time for DMA mode. The worst-case sustainable transfer time per 
sector for the device is calculated as follows: 

Streaming Transfer Time = (word 96) * (words (99:98) / 65536) 
The content of IDENTIFY DEVICE data word 96 may be affected by the host issuing a SET FEATURES 
subcommand 43h (Typical Host Interface Sector Time for DMA mode). Because of this effect, an IDENTIFY 
DEVICE command shall be issued after a SET FEATURES command that may affect these words. If the 
Streaming Feature Set is not supported by the device, the content of word 96 shall be zero. 
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6.17.53 Word 97: Streaming Access Latency - DMA and PIO 


Word 97 defines the Streaming Access Latency for DMA and PIO mode. The worst-case access latency of 
the device for a streaming command is calculated as follows: 

Access Latency = (word 97) * (words (99:98) / 256) 
The content of IDENTIFY DEVICE data word 97 may be affected by the host issuing a SET FEATURES 
subcommand 42h or C2h (Automatic Acoustic Management). Because of this effect, an IDENTIFY DEVICE 
command shall be issued after a SET FEATURES command that may affect these words. If the Streaming 
Feature Set is not supported by the device, the content of word 97 shall be zero. 


6.17.54 Words (99:98): Streaming Performance Granularity 


These words define the fixed unit of time that is used in IDENTIFY DEVICE data words (97:96) and (104), 
and SET FEATURES subcommand 43h, and in the Streaming Performance Parameters log, which is 
accessed by use of the READ LOG EXT command, and in the Command Completion Time Limit that is 
passed in streaming commands. The unit of time for this parameter shall be in microseconds, e.g., a value 
of 10000 indicates 10 milliseconds. If yy was returned by the drive for this parameter, then 

— the Command Completion Time Limit in the Features register for a streaming command shall be yy 
microseconds. 

— the Streaming Transfer Time shall be ( (word 96) * (yy/65536) ) microseconds, ( (word 104) * 
(yy/65536) ) microseconds, or ( (a Sector Time array entriy in the Streaming Performance 
Parameters log) * (yy/65536) ) microseconds. 

— The Streaming Access Latency shall be ((word 97) * (yy/256)) microseconds, or ((an Access Time 
array entries in the Streaming Performance Parameters log) * (yy/256)) microseconds. 

— taking these units into account, the host may calculate the estimated time for a streaming command 
of size S sectors as ( ( word 96 * S / 65536) + (word 97 / 256 ) ) * yy microseconds for DMA mode. 

— taking these units into account, the host may calculate the estimated time for a streaming command 
of size S sectors as ( ( word 104 * S / 65536) + (word 97 / 256 ) ) * yy microseconds for PIO mode. 


The value of the Streaming Performance Granularity is vendor specific and fixed for a device. 
6.17.55 Words (103:100): Maximum user LBA for 48-bit Address feature set 


Words (103:100) contain a value that is one greater than the maximum LBA in user accessable space when 
the 48-bit Addressing feature set is supported. The maximum value that shall be placed in this field is 
OOOOFFFFFFFFFFFFh. Support of these words is mandatory if the 48-bit Address feature set is supported. 


6.17.56 Word 104: Streaming Transfer Time - PIO 


Word 104 defines the Streaming Transfer Time for PIO mode. The worst-case sustainable transfer time per 
sector for the device is calculated as follows: 

Streaming Transfer Time = (word 104) * (words (99:98) / 65536) 
The content of IDENTIFY DEVICE data word 104 may be affected by the host issuing a SET FEATURES 
subcommand 43h (Typical Host Interface Sector Time for PIO mode). Because of this effect, an IDENTIFY 
DEVICE command shall be issued after a SET FEATURES command that may affect these words. If the 
Streaming Feature Set is not supported by the device, the content of word 104 shall be zero. 


6.17.57 Word 106: Physical sector size / Logical Sector Size 


If bit 14 of word 106 is set to one and bit 15 of word 106 is cleared to zero, the contents of word 106 contain 
valid information. If not, information is not valid in this word. 


Bit 13 of word 106 shall be set to one to indicate that the device has more than one logical sector per 
physical sector. 


Bit 12 of word 106 shall be set to 1 to indicate that the device has been formatted with a logical sector size 
larger than 256 words. Bit 12 of word 106 shall be cleared to O to indicate that words 117-118 are invalid 
and that the logical sector size is 256 words. 
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Bits (11:4) of word 106 are reserved. 


Bits (3:0) of word 106 indicate the size of the device physical sectors in power of two logical sectors. 
Examples: 

Bits (3:0): 0 = 2° = 1 logical sector per physical sector 

Bits (3:0): 1 =2*=2 logical sector per physical sector 

Bits (3:0): 2=2°=4 logical sector per physical sector 

Bits (3:0): 3 = 2° = 8 logical sector per physical sector 


6.17.58 Word 107: Inter-seek delay for ISO 7779 standard acoustic testing 

Word 107 is defined as the manufacturer’s recommended time delay between seeks during ISO-7779 
standard acoustic testing in microseconds (ISO 7779 value tp. See ISO 7779:1999 (E) Clause C.9 
Equipment Category: Disk units and storage subsystems. 

6.17.59 Words (111:108): World wide name 


Words 111-108 shall contain the optional value of the world wide name (WWN) for the device. 


Word 108 bits 15-12 shall contain 5h, indicating that the naming authority is IEEE. All other values are 
reserved. 


Words 108 bits 11-0 and word 109 bits 15-4 shall contain the Organization Unique Identifier (OUI) for 
the device manufacturer. The OUI shall be assigned by the IEEE/RAC as specified by ISO/IEC 
13213:1994 (See 3.1.80). 

The identifier may be obtained from: 

Institute of Electrical and Electronic Engineers, Inc. 

Registration Authority Committee 


445 Hoes Lane 
Piscataway, NJ 08855-1331 


Word 109 bits 3-0, word 110, and word 111 shall contain a value assigned by the vendor that is unique for 
the OUI domain. 

6.17.60 Words (115:112): Reserved for a 128-bit world wide name 

6.17.61 Word 116: Reserved for technical report. 

6.17.62 Words 117-118: Logical Sector Size 

Words 117,118 indicate the size of device logical sectors in words. The value of words 117,118 shall be 
equal to or greater than 256. The value in words 117,118 shall be valid when word 106 bit 12 is set to 1. All 
logical sectors on a device shall be 117,118 words long. 

6.17.63 Words (126:119): Reserved 

6.17.64 Word 127: Removable Media Status Notification feature set support 

If bit O of word 127 is set to one and bit 1 of word 127 is cleared to zero, the device supports the Removable 
Media Status Notification feature set. Bits (15:2) shall be cleared to zero. Support of this word is mandatory if 
the Removable Media Status Notification feature set is supported. 


6.17.65 Word 128: Security status 


Support of this word is mandatory if the Security feature set is supported. 
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Bit 8 of word 128 indicates the security level. If security mode is enabled and the security level is high, bit 8 
shall be cleared to zero. If security mode is enabled and the security level is maximum, bit 8 shall be set to 
one. When security mode is disabled, bit 8 shall be cleared to zero. 


Bit 5 of word 128 indicates the Enhanced security erase unit feature is supported. If bit 5 is set to one, the 
Enhanced security erase unit feature set is supported. 


Bit 4 of word 128 indicates that the security count has expired. If bit 4 is set to one, the security count is 
expired and SECURITY UNLOCK and SECURITY ERASE UNIT are command aborted until a power-on 
reset or hardware reset. 

Bit 3 of word 128 indicates security frozen. If bit 3 is set to one, the security is frozen. 

Bit 2 of word 128 indicates security locked. If bit 2 is set to one, the security is locked. 


Bit 1 of word 128 indicates security enabled. If bit 1 is set to one, the security is enabled. 


Bit O of word 128 indicates the Security Mode feature set supported. If bit O is set to one, security is 
supported. 


6.17.66 Words (159:129): Vendor specific. 
6.17.67 Word 160: CFA power mode 


Word 160 indicates the presence and status of a CFA feature set device that supports CFA Power Mode 1. 
Support of this word is mandatory if CFA Power Mode 1 is supported. 


If bit 13 of word 160 is set to one then the device shall be in CFA Power Mode 1 to perform one or more 
commands implemented by the device. 


If bit 12 of word 160 is set to one the device is in CFA Power Mode 0 (See 6.49.14). 


Bits (11:0) indicate the maximum average RMS current in Milliamperes required during 3.3V or 5V device 
operation in CFA Power Mode 1. 


6.17.68 Words (175:161): Reserved for assignment by the CompactFlash™ Association 

6.17.69 Words (205:176): Current media serial number 

Words (205:176) contain the current media serial number. Serial numbers shall consist of 60 bytes. The first 
40 bytes shall indicate the media serial number and the remaining 20 bytes shall indicate the media 
manufacturer. 

For removable ATA devices (e.g., flash media with native ATA interfaces) that do not support removable 
media, the first 20 words of this field shall be the same as words (46:27) of the IDENTIFY DEVICE data and 
the next ten words shall be the same as words (19:10) of the IDENTIFY DEVICE response. 

6.17.70 Words (254:206): Reserved. 

6.17.71 Word 255: Integrity word 

The use of this word is optional. If bits (7:0) of this word contain the signature A5h, bits (15:8) contain the 
data structure checksum. The data structure checksum is the two’s complement of the sum of all bytes in 


words (254:0) and the byte consisting of bits (7:0) in word 255. Each byte shall be added with unsigned 
arithmetic, and overflow shall be ignored. The sum of all 512 bytes is zero when the checksum is correct. 
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6.18 IDENTIFY PACKET DEVICE 

6.18.1 Command code 

Ath 

6.18.2 Feature set 

PACKET Command feature set 
— Use prohibited for devices not implementing the PACKET Command feature set. 
— Mandatory for devices implementing the PACKET Command feature set. 

6.18.3 Protocol 

PIO data-in (See Clause 11). 


6.18.4 Inputs 


| Register | 7] OT ST a Tt 


LBA Mid 
n 


LBA High 


Command 


Device register - 
DEV shall specify the selected device. 


6.18.5 Normal outputs 


| Register | 7] | 6 OT a 


LBA High na 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.18.6 Error outputs 


The device shall return command aborted if the device does not implement this command, otherwise, the 
device shall not report an error. 
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6.18.7 Prerequisites 
This command shall be accepted regardless of the state of DRDY. 
6.18.8 Description 


The IDENTIFY PACKET DEVICE command enables the host to receive parameter information from a device 
that implements the PACKET Command feature set. 


Some devices may have to read the media in order to complete this command. 


When the command is issued, the device sets the BSY bit to one, prepares to transfer the 256 words of 
device identification data to the host, sets the DRQ bit to one, clears the BSY bit to zero, and asserts INTRQ 
if nIEN is cleared to zero. The host may then transfer the data by reading the Data register. Table 18 defines 
the arrangement and meanings of the parameter words in the buffer. All reserved bits or words shall be zero. 


References to parallel implementation bus signals (e.g. DMACK, DMARQ, etc) apply only to parallel 
implementations. See Volume 3 for additional information on serial protocol. Some register bits (e.g. nIEN, 
SRST, etc.) have different requirements in the serial implementation (See Volume 3). 


Some parameters are defined as a group of bits. A word that is defined as a set of bits is transmitted with 
indicated bits on the respective data bus bit (e.g., bit 15 appears on DD15). 


Some parameters are defined as a 16-bit value. A word that is defined as a 16-bit value places the most 
significant bit of the value on bit DD15 and the least significant bit on bit DDO (See 3.2.9). 


Some parameters are defined as 32-bit values (e.g., words (61:60)). Such fields are transferred using two 
word transfers. The device shall first transfer the least significant bits, bits (15:0) of the value, on bits 
DD(15:0) respectively. After the least significant bits have been transferred, the most significant bits, bits 
(31:16) of the value, shall be transferred on DD(15:0) respectively (See 3.2.9). 


Some parameters are defined as a string of ASCII characters (See 3.2.9). 
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Table 18 - IDENTIFY PACKET DEVICE data 


| Word | O/M_| FIV | Description 


M General configuration bit-significant information: 
15-14 10=ATAPI device 
11 = Reserved 
13 Reserved 
12-8 Field indicates command packet set used by device 
7 1 = removable media device 
6-5 00 = Device shall set DRQ to one within 3 ms of receiving PACKET command. 
01 = Obsolete. 
10 = Device shall set DRQ to one within 50 us of receiving PACKET command. 
11 = Reserved 
Reserved 
Incomplete response 
00 = 12 byte command packet 
01 = 16 byte command packet 
1x = Reserved 


) a | LF UC Reserved 
| 2) | | | Unique configuration 
| 39 | | F |Reseved 
20622) c 1 ite Reseed < 
| 27-46 | M_| F | Modelnumber(40ASCiicharacters) 
paras | __|_F_| Reserved 
Capabilities 
15 1 = interleaved DMA supported 
Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 
14 1 = command queuing supported 
13 1 = overlap operation supported 
12 1 = ATA software reset required (Obsolete) 
11 1 = IORDY supported 
10 1 = IORDY may be disabled 
Shall be set to one. 
1 = DMA supported 
Devices which require the DMADIR bit in the Packet command shall clear this bit to 0 
Vendor specific 
Capabilities 
Shall be cleared to zero. 
Shall be set to one. 
Reserved 
Obsolete 
Shall be set to one to indicate a device specific Standby timer value minimum. 


mannan nNn 


Reserved 
= the fields reported in word 88 are valid 
= the fields reported in word 88 are not valid 
= the fields reported in words (70:64) are valid 
= the fields reported in words (70:64) are not valid 
Rcee 
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Table 18 - IDENTIFY PACKET DEVICE data (continued) 
ee on eA 


15 1 = DMADIR bit in the Packet command is required for DMA transfers 
0 = DMADIR bit in Packet command is not required for DMA transfers. 
14-11 Reserved 
10 1= DMA is supported 
1 = Multiword DMA mode 2 is supported 
1 = Multiword DMA mode 1 is supported 
1 = Multiword DMA mode 0 is supported 
1 = Ultra DMA mode 6 and below are supported 
1 = Ultra DMA mode 5 and below are supported 
1 = Ultra DMA mode 4 and below are supported 
1 = Ultra DMA mode 3 and below are supported 
1 = Ultra DMA mode 2 and below are supported 
1 = Ultra DMA mode 1 and below are supported 
1 = Ultra DMA mode 0 is supported 
15-11 Reserved 
10 1 = Multiword DMA mode 2 is selected 
0 = Multiword DMA mode 2 is not selected 
9 1 = Multiword DMA mode 1 is selected 
0 = Multiword DMA mode 1 is not selected 
8 1 = Multiword DMA mode 0 is selected 
0 = Multiword DMA mode 0 is not selected 
7-3 Reserved 
2 1 = Multiword DMA mode 2 and below are supported 
Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 
1 1 = Multiword DMA mode 1 and below are supported 
Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 
0 1 = Multiword DMA mode 0 is supported Multiword DMA mode selected 
Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 
15-8 Reserved 
7-0 PIO transfer modes supported 
Minimum Multiword DMA transfer cycle time per word 
15-0 Cycle time in nanoseconds 
Manufacturer's recommended Multiword DMA transfer cycle time 
15-0 Cycle time in nanoseconds 
Minimum PIO transfer cycle time without flow control 
15-0 Cycle time in nanoseconds 
Minimum PIO transfer cycle time with IORDY flow control 
15-0 Cycle time in nanoseconds 


| 69-70 | «| ~F__| Reserved (for future command overlap and queuing 

| 71 | O | F | Typical time inns from receiptof PACKET commandtobusrelease. 
| 72 | © | F | Typical time inns from receipt of SERVICE commandto BSY clearedtozero 
| 73-74 | | F [Reserved 


75 Queue depth 
15-5 Reserved 
4-0 Maximum queue depth supported - 1 
76-79 Reserved for Serial ATA 


qn 
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Table 18 - IDENTIFY PACKET DEVICE data (continued) 


Major version number 
0000h or FFFFh = device does not report version 
15 Reserved 
14 Reserved for ATA/ATAPI-14 
13 Reserved for ATA/ATAPI-13 
12 Reserved for ATA/ATAPI-12 
11 Reserved for ATA/ATAPI-11 
10 Reserved for ATA/ATAPI-10 
Reserved for ATA/ATAPI-9 
Reserved for ATA/ATAPI-8 
1 = Supports ATA/ATAPI-7 
1 = supports ATA/ATAPI-6 
1 = supports ATA/ATAPI-5 
1 = supports ATA/ATAPI-4 
Obsolete 
Obsolete 
Obsolete 
Reserved 
Minor version number 
0000h or FFFFh=device does not report version 
0001h-FFFEh=See 6.17.41 
Command set supported. If words (83:82) = O0000h or FFFFh command set notification not 
supported. 
15 Obsolete 
14 1 = NOP command supported 
13 1 = READ BUFFER command supported 
12 1 = WRITE BUFFER command supported 
11 Obsolete 
10 1 = Host Protected Area feature set supported 
1 = DEVICE RESET command supported 
1 = SERVICE interrupt supported 
= release interrupt supported 
= look-ahead supported 
1 = write cache supported 
Shall be set to one indicating the PACKET Command feature set is supported. 
1 = Power Management feature set supported 
1 = Removable Media feature set supported 
1 = Security Mode feature set supported 
1 = SMART feature set supported 
Command sets supported. If words (83:82) = O0000h or FFFFh command set notification not 
supported. 
Shall be cleared to zero 
Shall be set to one 
Reserved 
1 = FLUSH CACHE command supported 
1 = Device Configuration Overlay feature set supported 
Reserved 
1 = AUTOMATIC Acoustic Management feature set supported 
1 = SET MAX security extension supported 
See Address Offset Reserved Area Boot, INCITS TR27:2001 
1 = SET FEATURES subcommand required to spinup after power-up 
1 = Power-Up In Standby feature set supported 
1 = Removable Media Status Notification feature set supported 
Reserved 
1 = DOWNLOAD MICROCODE command supported 


7XxXx<TADAAAMAAMNANDN 
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Table 18 - IDENTIFY PACKET DEVICE data (continued) 


Hcl ez an PN 


Command set/feature supported extension. If words 82, 83, and 84 = 0000h or FFFFh command 
set notification extension is not supported. 
15 Shall be cleared to zero 
14 Shall be set to one 
13-0 Reserved 


Command set/feature enabled. If words 85, 86, and 87 = 0000h or FFFFh command set enabled 
notification is not supported. 


x Obsolete 
F 1 = NOP command enabled 
F 1 = READ BUFFER command enabled 
F 1 = WRITE BUFFER command enabled 
Xx Obsolete 
V 1 = Host Protected Area feature set enabled 
F 1 = DEVICE RESET command enabled 
Vv 1 = SERVICE interrupt enabled 
Vv = release interrupt enabled 
V 1 = look-ahead enabled 
V 1 = write cache enabled 
F Shall be set to one indicating the PACKET Command feature set is supported. 
F 1 = Power Management feature set enabled 
V 1 = Removable Media feature set enabled 
Vv 1 = Security Mode feature set enabled 
V 1 = SMART feature set enabled 
Command set/feature enabled. If words 85, 86, and 87 = 0000h or FFFFh command set enabled 
notification is not supported. 
F Reserved 
Vv 1 = FLUSH CACHE command supported 
F 1 = Device Configuration Overlay feature set supported 
F Reserved 
Vv 1 = Automatic Acoustic Management feature set enabled 
Vv 1 = SET MAX security extension enabled by a SET MAX SET PASSWORD 
V See Address Offset Reserved Area Boot, INCITS TR27:2001 
F 1 = SET FEATURES subcommand required to spinup after power-up 
Vv 1 = Power-Up In Standby feature set enabled 
V 1 = Removable Media Status Notification feature set enabled via the SET FEATURES 
command. 
F Reserved 
F 1 = DOWNLOAD MICROCODE command enabled 
87 M Command set/feature default. If words 85, 86, and 87 = 0000h or FFFFh command set default 
notification is not supported. 
F 15 Shall be cleared to zero 
F 14 Shall be set to one 
F 13-0 Reserved 
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Table 18 - IDENTIFY PACKET DEVICE data (continued) 


Ue 


Reserved 

1 = Ultra DMA mode 6 is selected 

0 = Ultra DMA mode 6 is not selected 

1 = Ultra DMA mode 5 is selected 

0 = Ultra DMA mode 5 is not selected 

1 = Ultra DMA mode 4 is selected 

0 = Ultra DMA mode 4 is not selected 

1 = Ultra DMA mode 3 is selected 

0 = Ultra DMA mode 3 is not selected 

1 = Ultra DMA mode 2 is selected 

0 = Ultra DMA mode 2 is not selected 

1 = Ultra DMA mode 1 is selected 

0 = Ultra DMA mode 1 is not selected 

1 = Ultra DMA mode 0 is selected 

0 = Ultra DMA mode 0 is not selected 

Reserved 

1 = Ultra DMA mode 6 and below are supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 

1 = Ultra DMA mode 5 and below are supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 

1 = Ultra DMA mode 4 and below are supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 

1 = Ultra DMA mode 3 and below are supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 

1 = Ultra DMA mode 2 and below are supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 

1 = Ultra DMA mode 1 and below are supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 

1 = Ultra DMA mode 0 is supported 

Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 
[Reserved 


| 89-92 | __—i|_~F | Reserved 
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Table 18 - IDENTIFY PACKET DEVICE data (continued) 
Ne OOP: [EIA |S tO ee 


93 Hardware reset result. The contents of bits (12:0) of this word shall change only during the 
execution of a hardware reset. 
15 Shall be cleared to zero. 
14 Shall be set to one. 
13 1 = device detected CBLID- above Vin 
O = device detected CBLID- below Vi. 
Device 1 hardware reset result. Device 0 shall clear these bits to zero. Device 1 shall 
set these bits as follows: 
12 Reserved. 
11 0 = Device 1 did not assert PDIAG-. 
1 = Device 1 asserted PDIAG-. 
10-9 These bits indicate how Device 1 determined the device number: 
00 = Reserved. 
01 = a jumper was used. 
10 = the CSEL signal was used. 
11 = some other method was used or the method is unknown. 
8 Shall be set to one. 
Device 0 hardware reset result. Device 1 shall clear these bits to zero. Device O shall 
set these bits as follows: 
7 Reserved. 
6 0 = Device 0 does not respond when Device 1 is selected. 
1 = Device 0 responds when Device 1 is selected. 
5 0 = Device 0 did not detect the assertion of DASP-. 
1 = Device 0 detected the assertion of DASP-. 
0 = Device 0 did not detect the assertion of PDIAG-. 
1 = Device 0 detected the assertion of PDIAG-. 
0 = Device 0 failed diagnostics. 
1 = Device 0 passed diagnostics. 
These bits indicate how Device 0 determined the device number: 
00 = Reserved. 
01 = a jumper was used. 
10 = the CSEL signal was used. 
11 = some other method was used or the method is unknown. 
0 Shall be set to one. 


94 . 15-8 Vendor’s recommended acoustic management value. 
7-0 Current automatic acoustic mamagement value. 
95-124 Reserved 


D125 —[-M_[-F ATAPI byte Gaunt 0 behavior > 
fe 2G 1] | ee | OD solete en 8 eeeeesssssssesSsS 


127 Removable Media Status Notification feature set support 
F 15-2 Reserved 
F 1-0 00=Removable Media Status Notification feature set not supported 
01 = Removable Media Status Notification feature set supported 
10 = Reserved 
11 = Reserved 
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Table 18 - IDENTIFY PACKET DEVICE data (continued) 


| Word _{ OfM | FIV 


e 
Security status 
15-9 Reserved 
Security level 0 = High, 1 = Maximum 
Reserved 
1 = Enhanced security erase supported 
1 = Security count expired 
1 = Security frozen 
1 = Security locked 
1 = Security enabled 
1= Security supported 


129-159 [xe venioseece os  ——=<$<<=<$J 
160-175 | | Reserved for assignment by the CompactFlash™ Association 
176-254 | £ | Reserved Reserved 


255 Integrity word 
2 . Checksum 
Signature 


Key: 

O/M = Mandatory/optional requirement. 

M = Support of the word is mandatory. 

O = Support of the word is optional. 

* = See 6.17.49. 

F/V = Fixed/variable content. 

F = the content of the word is fixed and does not change. For removable media devices, these values may 
change when media is removed or changed. 

V = the contents of the word is variable and may change depending on the state of the device or the 
commands executed by the device. 

X = the content of the word may be fixed or variable. 


nm<e<<ccm7<T7 
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6.18.9 Word 0: General configuration 


Bits (15:14) of word O indicate the type of device. Bit 15 shall be set to one and bit 14 shall be cleared to 
zeroto indicate the device implements the PACKET Command feature set. 


Bits (12:8) of word O indicate the command packet set implemented by the device. This value follows the 
peripheral device type value as defined in SCSI Primary Commands, ANSI INCITS 301:1997. 


Reserved for ACS IT8 (Graphic arts pre-press devices) 
Array controller device 
Optical card reader/writer device 


Bit 7 if set to one indicates that the device has removable media. 


Bits (6:5) of word O indicate the DRQ response time when a PACKET command is received. A value of 00b 
indicates a maximum time of 3 ms from receipt of PACKET to the setting of DRQ to one. A value of 10b 
indicates a maximum time of 50 us from the receipt of PACKET to the setting of DRQ to one. The value 11b 
is reserved. 

If bit 2 is set to one it indicates that the content of the IDENTIFY DEVICE data is incomplete. This will occur if 
the device supports the Power-up in Standby feature set and required data is contained on the device media. 
In this case the content of at least word 0 and word 2 shall be valid. 


Bits (1:0) of word O indicate the packet size the device supports. A value of OOb indicates that a 12-byte 
packet is supported; a value of 01b indicates a 16 byte packet. The values 10b and 11b are reserved. 


6.18.10 Word 1: Reserved 

6.18.11 Word 2: Specific configuration 

Word 2 shall have the same content described for word 2 of the IDENTIFY DEVICE command. 
6.18.12 Words (9:3): Reserved 

6.18.13 Words (19:10): Serial number 


The use of these words is optional. If not implemented, the content shall be zeros. If implemented, the 
content shall be as described in words (19:10) of the IDENTIFY DEVICE command (See 6.17). 


6.18.14 Words (22:20): Reserved 
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6.18.15 Words (26:23): Firmware revision 

Words (26:23) shall have the content described for words (26:23) of the IDENTIFY DEVICE command. 
6.18.16 Words (46:27): Model number 

Words (46:27) shall have the content described for words (46:27) of the IDENTIFY DEVICE command. 
6.18.17 Words (48:47): Reserved 

6.18.18 Word 49: Capabilities 


Bit 15 of word 49 is used to indicate that the device supports interleaved DMA data transfer for overlapped 
DMA commands. Devices which require the DMADIR bit in the Packet command shall clear this bit to 0. 


Bit 14 of word 49 is used to indicate that the device supports command queuing for overlapped commands. If 
bit 14 is set to one, bit 13 shall be set to one. 


Bit 13 of word 49 is used to indicate that the device supports command overlap operation. 

Bit 12 of word 49 is obsolete. 

Bit 11 of word 49 is used to determine whether a device supports IORDY. If this bit is set to one, then the 
device supports IORDY operation. If this bit is zero, the device may support IORDY. This ensures backward 
compatibility. If a device supports PIO mode 3 or higher, then this bit shall be set to one. If the serial interface 
is implemented, this bit shall be set to one. 

Bit 10 of word 49 is used to indicate a device’s ability to enable or disable the use of IORDY. If this bit is set 
to one, then the device supports the disabling of IORDY. Disabling and enabling of IORDY is accomplished 
using the SET FEATURES command. If the serial interface is implemented, this bit shall be set to one. 


Bit 9 of word 49 shall be set to one. 


Bit 8 of word 49 indicates that DMA is supported. Devices which require the DMADIR bit in the Packet 
command shall clear this bit to 0 


6.18.19 Word 50: Capabilities 


Word 50 shall have the content described for word 50 of the IDENTIFY DEVICE command. Support of this 
word is mandatory if the STANDBY command is supported. 


6.18.20 Word 51: Obsolete 


6.18.21 Word 52: Reserved 


6.18.22 Word 53: Field validity 

Word 53 shall have the content described for word 53 of the IDENTIFY DEVICE command. 

6.18.23 Words (61:54): Reserved 

6.18.24 Word 62: DMADIR 

ATAPI devices that use a serial ATA bridge chip for connection to a serial ATA host may require use of the 


DMADIR bit to indicate transfer direction for Packet DMA commands. Word 62 is used to indicate if such 
support is required. 
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If bit 15 of word 62 is set to one, then DMADIR bit in the Packet Command is required by the device for 
Packet DMA and Bits 2:0 of word 63, bits 15 and 8 in word 49, and bits 6:0 of word 88 shall be cleared to O,. 


If bit 15 of word 62 is cleared to 0, DMADIR bit in the PACKET command is not required. If bit 15 of word 62 
is cleared to zero, then all bits of word 62 shall be cleared to zero. 


Bits (14:11) are reserved. 


Bits (10:1) indicate DMA mode support. Since the DMADIR bit is only used for a Serial ATAPI device, all of 
these bits are set to 1. 


6.18.25 Word 63: Multiword DMA transfer 

Word 63 identifies the Multiword DMA transfer modes supported by the device and indicates the mode that is 
currently selected. Only one DMA mode shall be selected at any given time. If an Ultra DMA mode is 
enabled, then no Multiword DMA mode shall be enabled. If a Multiword DMA mode is enabled then no Ultra 
DMA mode shall be enabled. 

Bit (15:11) are Reserved. 

Bits 10:8 shall have the content described for word 63 of the IDENTIFY DEVICE command. 

Bits (7:3) are Reserved 

If bit 2 of Word 63 is set to one, then Multiword DMA modes 2 and below are supported. If this bit is cleared 
to zero, then Multiword DMA mode 2 is not supported. If Multiword DMA mode 2 is supported, then Multiword 
DMA modes 1 and 0 shall also be supported. 

If bit 2 of Word 63 is set to one, bits (1:0) shall be set to one. If the serial interface is implemented, this bit 
shall be set to one except this bit shall be cleared 0 for Serial ATAPI devices requiring the DMADIR bit in the 
PACKET command. 

If bit 1 of Word 63 is set to one, then Multiword DMA modes 1 and below are supported. If this bit is cleared 
to zero, then Multiword DMA mode 1 is not supported. If Multiword DMA mode 1 is supported, then Multiword 
DMA mode 0 shall also be supported. 

If bit 1 of Word 63 is set to one, bit O shall be set to one. If the serial interface is implemented, this bit shall be 
set to one except this bit shall be cleared to 0 for Serial ATAPI devices which require the DMADIR bit in the 
PACKET command. 

If bit O of word 63 is set to one, then Multiword DMA mode 0 is supported. If the serial interface is 
implemented, this bit shall be set to one except this bit shall be cleared to O for Serial ATAPI devices which 
require the DMADIR bit in the PACKET command. 

6.18.26 Word 64: PIO transfer mode supported 

Word 64 shall have the content described for word 64 of the IDENTIFY DEVICE command. 

6.18.27 Word 65: Minimum multiword DMA transfer cycle time per word 

Word 65 shall have the content described for word 65 of the IDENTIFY DEVICE command. 


6.18.28 Word 66: Device recommended multiword DMA cycle time 


Word 66 shall have the content described for word 66 of the IDENTIFY DEVICE command. 
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6.18.29 Word 67: Minimum PIO transfer cycle time without flow control 

Word 67 shall have the content described for word 67 of the IDENTIFY DEVICE command. 

6.18.30 Word 68: Minimum PIO transfer cycle time with IORDY 

Word 68 shall have the content described for word 68 of the IDENTIFY DEVICE command. 

6.18.31 Word (70:69): Reserved 

6.18.32 Word 71: PACKET to bus release time 

Word 71 shall contain the time (for 99.7% of the occurances) in microseconds from the receipt of a PACKET 
command until the device performs a bus release. Support of this word is mandatory if the Overlap or 
Queuing feature set is supported. 

6.18.33 Word 72: SERVICE to bus release time 

Word 72 shall contain the time (for 99.7% of the occurances) in microseconds from the receipt of a SERVICE 
command until the device performs a bus release. Support of this word is mandatory if the Overlap or 
Queuing feature set is supported. 

6.18.34 Word (74:73): Reserved 

6.18.35 Word 75: Queue depth 


Bits (4:0) of word 75 shall have the content described for word 75 of the IDENTIFY DEVICE command. 
Support of this word is mandatory if the Queuing feature set is supported. 


6.18.36 Words (79:76): Reserved for Serial ATA 

6.18.37 Word 80: Major revision number 

Word 80 shall have the content described for word 80 of the IDENTIFY DEVICE command. 

6.18.38 Word 81: Minor revision number 

Word 81 shall have the content described for word 81 of the IDENTIFY DEVICE command. 

6.18.39 Words (84:82): Features/command sets supported 

Words (84:82) shall have the content described for words (84:82) of the IDENTIFY DEVICE command 
except that bit 4 of word 82 shall be set to one to indicate that the PACKET Command feature set is 
supported. 

6.18.40 Words (87:85): Features/command sets enabled 

Words (87:85) shall have the content described for words (87:85) of the IDENTIFY DEVICE command 
except that bit 4 of word 85 shall be set to one to indicate that the PACKET Command feature set is 
supported. 


6.18.41 Word 88:Ultra DMA modes 


Word 88 shall have the content described for word 88 of the IDENTIFY DEVICE command, except 
bits 6:0 shall be cleared to O for Serial ATAPI devices which require the DMADIR bit in the Packet command. 


Page 151 


T13/1532D Volume 1 Revision 4b 


6.18.42 Word 89: Time required for Security erase unit completion 

Word 89 shall have the content described for word 89 of the IDENTIFY DEVICE command. 
6.18.43 Word 90: Time required for Enhanced security erase unit completion 

Word 90 shall have the content described for word 90 of the IDENTIFY DEVICE command. 
6.18.44 Word (92:91): Reserved 

6.18.45 Word 93: Hardware reset results 


Word 93 shall have the content described for word 93 of the IDENTIFY DEVICE command. Support of bits 
(13:15) is mandatory. Support of bits (12:0) is optional. 


6.18.46 Word 94: Current automatic acoustic management value 

Word 94 shall have the content described for word 94 of the IDENTIFY DEVICE command. 
6.18.47 Word (124:95): Reserved 

6.18.48 Word 125 ATAPI byte count=0 behavior. 


If the contents of word 125 are OOOOh and the value of the byte count limit is zero, the device shall return 
command aborted. 


If the contents of word 125 are non-zero and the value of the byte count limit is zero, the device shall use the 
contents of word 125 as the actual byte count limit for the current command and shall not abort. 


The device may be reconfigured to report a new value. However, after the device is reconfigured, the 
content of word 125 reported shall not change until after the next hardware reset or power-on reset event. 


6.18.49 Word 126: Obsolete 
6.18.50 Word 127: Removable Media Status Notification feature set support 


Word 127 shall have the content described for word 127 of the IDENTIFY DEVICE command. Support of this 
word is mandatory if the Removable Media Status Notification feature set is supported. 


6.18.51 Word 128: Security status 


Word 128 shall have the content described for word 128 of the IDENTIFY DEVICE command. Support of this 
word is mandatory if the Security feature set is supported. 


6.18.52 Words (160:129): Reserved 


6.18.53 Words (175:161): Reserved for assignment by the CompactFlash™ Association 


6.18.54 Words (254:176): Reserved 


6.18.55 Word 255: Integrity Word 


Word 255 shall have the content described for word 255 of the IDENTIFY DEVICE command. Word 255 
should be implemented. 
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6.19 IDLE 

6.19.1 Command code 

E3h 

6.19.2 Feature set 

Power Management feature set. 
— This command is mandatory for devices not implementing the PACKET Command feature set. 
— Power Management feature set is mandatory when power management is not implemented by 

the PACKET command set implemented by the device. 

— This command is mandatory when the Power Management feature set is implemented. 

6.19.3 Protocol 

Non-data (See Clause 11). 

6.19.4 Inputs 


Values other than zero in the Sector Count register when the IDLE command is issued shall determine the 
time period programmed into the Standby timer. Table 19 defines these values. 


| Register, |] 7 OT 6 UT ST a 2 
| Features Pa 
Pp LBALow Pn 


pC LBAMig Pa 
ft = — OB igh ia ee 
| Device | obs | na obs | DEV | ma | ma | na | na_| 
pe Command) = a, 7 ES 


Device register - 
DEV shall indicate the selected device. 


Table 19 - Automatic Standby timer periods 


Sector Count register Corresponding timeout period 
contents 


0 (00h) Timeout disabled 
1-240 (O1h-FOh) (value * 5) seconds 
241-251 (Fih-FBh) ((value - 240) *30) minutes 
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6.19.5 Normal outputs 


| Register | 7] | G6 TS a a 


Bsy_| DRDY | DF | ona_| DRQ [ na _| na | ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.19.6 Error outputs 


The device shall return command aborted if the device does not support the Power Management feature set. 


| Register | 7] 6 | a a 


| Status | BSY [| DRDY [| DF | na | ORQ | na | na _{ ERR | 


Error register - 

ABRT shall be set to one if Power Management feature set is not supported. ABRT may be set to 

one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.19.7 Prerequisites 
DRDY set to one. 
6.19.8 Description 


The IDLE command allows the host to place the device in the Idle mode and also set the Standby timer. 
INTRQ may be asserted even though the device may not have fully transitioned to Idle mode. 


If the Sector Count register is non-zero then the Standby timer shall be enabled. The value in the Sector 


Count register shall be used to determine the time programmed into the Standby timer (See 4.5). If the 
Sector Count register is zero then the Standby timer is disabled. 
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6.20 IDLE IMMEDIATE 
6.20.1 Command code 
Eth 
6.20.2 Feature set 
Power Management feature set. 
— This command is mandatory for devices not implementing the PACKET Command feature set. 
— Power Management feature set is mandatory when power management is not implemented by 
the PACKET command set implemented by the device. 
— This command is mandatory when the Power Management feature set is implemented. 
— The Unload Feature of the command is optional. 


6.20.3 Protocol 


Non-data (See Clause 11). 


6.20.4 Inputs (Default Fuction) 


| Register | 7] OT 6 OT a fT 
ee a a ee Se ee 


Device register - 
DEV shall specify the selected device. 


6.20.5 Inputs (Unload Feature) 


| Register | 7] OT 6 OT 5 a fT 


Device register - 
DEV shall specify the selected device. 
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6.20.6 Normal outputs (Default Fuction) 


| Register | 7] | GT a a 


Bsy_| DRDY | DF | ona_ | DRQ [ na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.20.7 Normal outputs (Unload Feature) 


| Register | 7] | 6 OT a a 


Status Bsy_ [| DRDY | DF | ona | ORQ {na _ | na_| ERR | 


LBA Low - 
C4h to indicate that unloading successfully completed. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.20.8 Error outputs 


The device shall return command aborted if the device does not support the Power Management feature set. 


| Register | 7] 6 OT a 


| Status | BSY [ DRDY [| DF | na | ORQ | na | na _ { ERR | 
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Error register - 

ABRT shall be set to one if Power Management feature set is not supported. ABRT may be set to 

one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.20.9 Prerequisites 
DRDY set to one. 


6.20.10 Description 

Default Fuction: 

The IDLE IMMEDIATE command allows the host to immediately place the device in the Idle mode. INTRQ 
may be asserted even though the device may not have fully transitioned to Idle mode (See 4.5). 


Unload Feature: 

The UNLOAD FEATURE of the IDLE IMMEDIATE command allows the host to immediately unload/park the 
heads. The device shall stop read look-ahead if it is in process. If the device is performing a write operation, 
the device shall suspend writing cached data onto the media as soon as possible, and keep unwritten 
sectors stored in the buffer until receiving a new command. 


A device that supports load/unload technology shall retract the head(s) onto the ramp position as soon as 
receiving this command. INTRQ shall be asserted and BSY shall be cleared after the head(s) is(are) 
completely retracted onto the ramp position and latched if available. The time to complete the unload 
operation is vendor specific, this typically would be within 500 milliseconds of receiving the command. The 
unload controlling method by the Unload Feature of the Idle Immediate command shall be the same as that 
by Power mode transition, and shall not effect the specification of normal load/unload times per device life. 


A device that supports contact start/stop technology shall seek to the landing zone. INTRQ shall be asserted 
and BSY shall be cleared after seek completion. The time to complete the seek operation is vendor specific, 
this typically would be within 300 milliseconds of receiving this command. 


The device shall stay at Low Power Idle mode, shall not go into Standby mode and shall not load the head(s) 
onto the media until receiving a new command. Power consumption of the device is not an issue for this 
case. If a device receives this command while the head(s) is(are) currently on ramp/parked no physical 
action is needed. 


The device shall retain data in the write cache and resume writing the cached data onto the media after 


receiving a Software Reset, a Hardware Reset, or any new command except IDLE IMMEDIATE with 
UNLOAD FEATURE. 
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6.21 MEDIA EJECT 
6.21.1 Command code 
EDh 
6.21.2 Feature set 
Removable Media Status Notification feature set 
— Mandatory for devices not implementing the PACKET command feature set and implementing 
the Removable Media Status Notification feature set. 


— Prohibited for devices implementing the PACKET command feature set. 


Removable Media feature set 


— Mandatory for devices not implementing the PACKET command feature set and implementing 
the Removable Media feature set. 


— Prohibited for devices implementing the PACKET command feature set. 
6.21.3 Protocol 
Non-data (See Clause 11). 


6.21.4 Inputs 


| Register | 7] 6 TT a 


Device register - 
DEV shall specify the selected device. 


6.21.5 Normal outputs 


| Register | 7] | GT a a 


BSsy_[ DRDY | DF | na | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
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DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
6.21.6 Error outputs 


If the device does not support this command, the device shall return command aborted. 


| Register | 7] | ST a 


| Status | SY | DRDY [| DF | na | ORQ | na | na _ { ERR | 


Error register - 
ABRT shall be set to one if device does not support this command. ABRT may be set to one if the 
device is not able to complete the action requested by the command. 
NM (No Media) shall be set to one if no media is present in the device. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to Zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.21.7 Prerequisites 
DRDY set to one. 
6.21.8 Description 


This command causes any pending operations to complete, spins down the device if needed, unlocks the 
media if locked, and ejects the media. The device keeps track of only one level of media lock. 


Page 159 


T13/1532D Volume 1 Revision 4b 


6.22 MEDIA LOCK 
6.22.1 Command code 
DEh 
6.22.2 Feature set 
Removable Media Status Notification feature set 
— Optional for devices not implementing the PACKET command feature set and implementing the 
Removable Media Status Notification feature set. 


— Prohibited for device implementing the PACKET command feature set. 


Removable Media feature set 


— Mandatory for devices not implementing the PACKET command feature set and implementing 
the Removable Media feature set. 


— Prohibited for devices implementing the PACKET command feature set. 
6.22.3 Protocol 
Non-data (See Clause 11). 


6.22.4 Inputs 


| Register | 7 OT 6 UT TT 


Device register - 
DEV shall specify the selected device. 


6.22.5 Normal outputs 


| Register | 7] | 6 OT a 


BSsy_[ DRDY | DF | na | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
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DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.22.6 Error outputs 


If the device does not support this command, the device shall return command aborted. 


| Register | 7] OT ST a a 


| Status | SY [ DRDY | DF | na | ORQ | na | na _{ ERR | 


Error register - 
ABRT shall be set to one if device does not support this command. ABRT may be set to one if the 
device is not able to complete the action requested by the command. 
NM (No Media) shall be set to one if no media is present in the device. 
MCR (Media Change Request) shall be set to one if the device is locked and a media change 
request has been detected by the device. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.22.7 Prerequisites 
DRDY set to one. 
6.22.8 Description 


This command shall be used to lock the media, if Media Status Notification is disabled. If Media Status 
Notification is enabled, this command shall return good status (no ERR bit in the Status register) and perform 
no action. 


If the media is unlocked and media is present, the media shall be set to the LOCKED state and no Error 
register bit shall be set to one. The device keeps track of only one level of media lock. Subsequent MEDIA 
LOCK commands, while the media is in the LOCKED state, do not set additional levels of media locks. 


If the media is locked, the status returned shall indicate whether a media change request has been detected 
by the device. If a media change request has been detected, the MCR bit in the Error register and the ERR 
bit in the Status register shall be set to one. 


When media is in the LOCKED state, the device shall respond to the media change request button, by 


setting the MCR bit in the Error register and the ERR bit in the Status register to one, until the media 
LOCKED condition is cleared. 
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6.23 MEDIA UNLOCK 
6.23.1 Command code 
DFh 
6.23.2 Feature set 
Removable Media Status Notification feature set 
— Optional for devices not implementing the PACKET command feature set and implementing the 
Removable Media Status Notification feature set. 


— Prohibited for devices implementing the PACKET command feature set. 


Removable Media feature set 


— Mandatory for devices not implementing the PACKET command feature set and implementing 
the Removable Media feature set. 


— Prohibited for devices implementing the PACKET command feature set. 
6.23.3 Protocol 
Non-data (See Clause 11). 


6.23.4 Inputs 


| Register | 7] 6 TT a 


Device register - 
DEV shall specify the selected device. 


6.23.5 Normal outputs 


| Register | 7] | 6 OT a a 


BSsy_[ DRDY | DF | na | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
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DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
6.23.6 Error outputs 


If the device does not support this command, the device shall return command aborted. 


| Register | 7] | ST a 


| Status | SY [ DRDY | DF | na | ORQ | na | na _{ ERR | 


Error register - 
ABRT shall be set to one if device does not support this command. ABRT may be set to one if the 
device is not able to complete the action requested by the command. 
NM (No Media) shall be set to one if no media is present in the device. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to Zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.23.7 Prerequisites 

DRDY set to one. 

6.23.8 Description 

This command can be used to unlock the device, if Media Status Notification is disabled. If Media Status 
Notification is enabled, this command will return good status (no ERR bit in the Status register) and perform 
no action. 

If the media is present, the media shall be set to the UNLOCKED state and no Error register bit shall be set 
to one. The device keeps track of only one level of media lock. A single MEDIA UNLOCK command unlocks 


the media. 


If a media change request has been detected by the device prior to the issuance of this command, the media 
shall be ejected at MEDIA UNLOCK command completion. 
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6.24 NOP 

6.24.1 Command code 

00h 

6.24.2 Feature set 

General feature set 
— Optional for devices not implementing the PACKET Command feature set. 
— Mandatory for devices implementing the PACKET Command feature set. 
— Mandatory for devices implementing the Overlapped feature set. 

6.24.3 Protocol 


Non-data (See Clause 11). 


6.24.4 Inputs 


| Register | 7] 6 UT TT aT 
tea Low [| na 


Pp LBAMig Pa 
ia eat SUEAIBIGHY aaa) er ot We A Sd 
| Device | obs | na obs | DEV | ma _ | na | na | na | 
(SR 2 ne | 


Features register - 


bac (A 
code 
3 = ee — 
outstanding queued commands. 
outstanding queued commands. 


02h-FFh Reserved Return command aborted and do not abort any 
outstanding queued commands. 
Device register - 
DEV shall specify the selected device. 


6.24.5 Normal outputs 
This command always fails with an error. 
6.24.6 Error outputs 


The Command Block registers, other than the Error and Status registers, are not changed by this command. 
This command always fails with the device returning command aborted. 
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| Register | 7] | 6 | a 
Initial value 


Initial value 
| Status | BSY | DRDY | DF | na | ORQ | na | na _{ ERR | 


Error register - 
ABRT shall be set to one. 
Sector Count, LBA Low, LBA Mid, LBA High, Device - 
value set by host is not changed. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one. 


6.24.7 Prerequisites 

DRDY set to one. 

6.24.8 Description 

The device shall respond with command aborted. For devices implementing the Overlapped feature set, 


subcommand code OOh in the Features register shall abort any outstanding queue. Subcommand codes 01h 
through FFh in the Features register shall not affect the status of any outstanding queue. 
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6.25 PACKET 

6.25.1 Command code 

AOh 

6.25.2 Feature set 

PACKET Command feature set 


— Use prohibited for devices not implementing the PACKET Command feature set. 
— Mandatory for devices implementing the PACKET Command feature set. 


6.25.3 Protocol 
Packet (See Clause 11). 


6.25.4 Inputs 


| Register | 7] | ST a 
Tag 


EE 


Command AOh 


Features register - 
DMADIR - This bit indicates Packet DMA direction and is used only for devices that implement the 
Packet Command feature set with a Serial ATA bridge that require direction indication from the 
host. Support for this bit is determined by reading bit 15 of word 62 in the IDENTIFY PACKET 
DEVICE data. If bit 15 of word 62 is set to 1, the device requires the use of the DMADIR bit for 
Packet DMA commands. 


If the device requires the DMADIR bit to be set for Packet DMA operations and the current 
operations is DMA (i.e. bit 0, the DMA bit, is set), this bit indicates the direction of data transfer 
(0 = transfer to the device; 1 = transfer to the host). If the device requires the DMADIR bit to be 
set for Packet DMA operations but the current operations is PIO (i.e. bit 0, the DMA bit, is 
cleared), this bit is ignored. 


Since the data transfer direction will be set by the host as the command is constructed, the 
DMADIR bit should not conflict with the data transfer direction of the command. If a conflict 
between the command transfer direction and the DMADIR bit occurs, the device should return 
with an ABORTED command, and the sense key set to ILLEGAL REQUEST. 


If the device does not require the DMADIR bit for Packet DMA operations, this bit should be 
cleared to 0. 


A device that does not support the DMADIR feature may abort a command if the DMADIR bit is 
set to 1. 
OVL - This bit is set to one to inform the device that the PACKET command is to be overlapped. 
DMA - This bit is set to one to inform the device that the data transfer (not the command packet 
transfer) associated with this command is via Multiword DMA or Ultra DMA mode. 
Sector Count register - 
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Tag - If the device supports command queuing, this field contains the command Tag for the 
command being delivered. A Tag may have any value between O and 31 regardless of the 
queue depth supported. If queuing is not supported, this field is not applicable. 

Byte Count low and Byte Count high registers - 

These registers are written by the host with the maximum byte count that is to be transferred in any 

single DRQ assertion for PIO transfers. The byte count does not apply to the command packet 

transfer. If the PACKET command does not transfer data, the byte count is ignored. 


If the PACKET command results in a data transfer: 


1) the host should not set the byte count limit to zero. If the host sets the byte count limit to 
zero, the contents of IDENTIFY PACKET DEVICE data word 125 determines the expected 
behavior; 

2) the value set into the byte count limit shall be even if the total requested data transfer length 
is greater than the byte count limit; 

3) the value set into the byte count limit may be odd if the total requested data transfer length is 
equal to or less than the byte count limit; 

4) the value FFFFh is interpreted by the device as though the value were FFFEh. 


Device register - 
DEV shall specify the selected device. 


6.25.5 Normal outputs 
6.25.5.1 Awaiting command 


When the device is ready to accept the command packet from the host the register content shall be as 
shown below. 


| Register | 7 OT 6 TS a 


a 
| Status | BSY [na [| DMRD | SERV | DRQ | na | na _ {CHK _| 


Byte Count High/Low - shall reflect the value set by the host when the command was issued. 
Interrupt reason register - 

Tag - If the device supports command queuing and overlap is enabled, this field contains the 
command Tag for the command. A Tag value may be any value between 0 and 31 regardless of 
the queue depth supported. If the device does not support command queuing or overlap is 
disabled, this field is not applicable. 

REL - Shall be cleared to zero. 

I/O - Shall be cleared to zero indicating transfer to the device. 

C/D - Shall be set to one indicating the transfer of a command packet. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY - Shall be cleared to zero. 

DMRD (DMA ready) - Shall be cleared to zero. 

SERV (Service) - Shall be set to one if another command is ready to be serviced. If overlap is not 
supported, this bit is command specific. 

DRQ - Shall be set to one. 

CHK - Shall be cleared to zero. 
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6.25.5.2 Data transmission 


If overlap is not supported or not specified by the command, data transfer shall occur after the receipt of the 
command packet. If overlap is supported and the command specifies that the command may be overlapped, 
data transfer may occur after receipt of the command packet or may occur after the receipt of a SERVICE 
command. When the device is ready to transfer data requested by a data transfer command, the device sets 
the following register content to initiate the data transfer. 


| Register | 7 6 at 


a 
| Status | BSY [na [| DMRD | SERV | DRQ | na | na _ {CHK _| 


Byte Count High/Low - If the transfer is to be in PIO mode, the byte count of the data to be transferred for 
this DRQ assertion shall be presented. 


Valid byte count values are as follows: 


1) the byte count shall be less than or equal to the byte count limit value from the host; 

2) the byte count shall not be zero; 

3) the byte count shall be less than or equal to FFFEh; 

4) the byte count shall be even except for the last transfer of a command; 

5) if the byte count is odd, the last valid byte transferred is on DD(7:0) and the data on 
DD(15:8) is a pad byte of undefined value; 

6) if the last transfer of a command has a pad byte, the byte count shall be odd. 


Interrupt reason register - 

Tag - If the device supports command queuing and overlap is enabled, this field contains the 
command Tag for the command. A Tag value may be any value between 0 and 31 regardless of 
the queue depth supported. If the device does not support command queuing or overlap is 
disabled, this field is not applicable. 

REL - Shall be cleared to zero. 

I/O - Shall be cleared to zero if the transfer is to the device. Shall be set to one if the transfer is to the 
host. 

C/D - Shall be cleared to zero indicating the transfer of data. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY - Shall be cleared to zero. 

DMRD (DMA ready) - Shall be set to one if the transfer is to be a DMA or Ultra DMA transfer and the 
device supports overlap DMA. 

SERV (Service) - Shall be set to one if another command is ready to be serviced. If overlap is not 
supported, this bit is command specific. 

DRQ - Shall be set to one. 

CHK - Shall be cleared to zero. 
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6.25.5.3 Bus release (overlap feature set only) 


After receiving the command packet, the device sets BSY to one and clears DRQ to zero. If the command 
packet requires a data transfer, the OVL bit is set to one, the Release interrupt is disabled, and the device is 
not prepared to immediately transfer data, the device may perform a bus release by placing the following 
register content in the Command Block registers. If the command packet requires a data transfer, the OVL bit 
is set to one, and the Release interrupt is enabled, the device shall perform a bus release by setting the 
register content as follows. 


| CRegister | 7] | 6 CT CUT A 2 Ta 
Pp LBALOwW Pm 


na 
na 
| Status | BSY_ | DRDY [| DMRD | SERV | DRQ | na | na_ [CHK _| 


Byte Count High/Low - na. 
Interrupt reason register - 

Tag - If the device supports command queuing and overlap is enabled, this field contains the 
command Tag for the command. A Tag value may be any value between 0 and 31 regardless of 
the queue depth supported. If the device does not support command queuing or overlap is 
disabled, this field is not applicable. 

REL - Shall be set to one. 

I/O - Shall be cleared to zero. 

C/D - Shall be cleared to zero. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY - Shall be cleared to zero indicating bus release. 

DRDY - na. 

DMRD (DMA ready) - Shall be cleared to zero. 

SERV (Service) - Shall be set to one if another command is ready to be serviced. If overlap is not 
supported, this bit is command specific. 

DRQ - Shall be cleared to zero. 

CHK - Shall be cleared to zero. 


6.25.5.4 Service request (overlap feature set only) 

When the device is ready to transfer data or complete a command after the command has performed a bus 
release, the device shall set the SERV bit and not change the state of any other register bit (See 10). When 
the SERVICE command is received, the device shall set outputs as described in data transfer, successful 
command completion, or error outputs depending on the service the device requires. 


6.25.5.5 Successful command completion 


When the device has command completion without error, the device sets the following register content. 
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| Register | 7] 6 OT TT a CT 
pron a 
| _Interruptreason [| ag REL | VO | CC 
fo EBA ow) sit 


| ByteCountLow | 
an BAe COUTINIAIGN 5 atthe 3 2a as ee Ss oN ks 8 
| Device | Sobs_ | —na_{ obs | DEV | ma [| na | na | na_| 
| Status | BSY_ | DRDY [| DMRD | SERV | DRQ | na | na [CHK _| 


Byte Count High/Low -na. 
Interrupt reason register - 

Tag - If the device supports command queuing and overlap is enabled, this field contains the 
command Tag for the command. A Tag value may be any value between O and 31 
regardless of the queue depth supported. If the device does not support command queuing 
or overlap is disabled, this field is not applicable. 

REL - Shall be cleared to zero. 

I/O - Shall be set to one. 

C/D - Shall be set to one. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY - Shall be cleared to zero indicating command completion. 

DRDY - Shall be set to one. 

DMRD (DMA ready) - na. 

SERV (Service) - Shall be set to one if another command is ready to be serviced. If overlap is not 
supported, this bit is command specific. 

DRQ - Shall be cleared to Zero. 

CHK - Shall be cleared to zero. 


6.25.6 Error outputs 


The device shall not terminate the PACKET command with an error before the last byte of the command 
packet has been written (See Clause 11). 


| Register | 7] OT 6 OT a ft 
Bees BRIO es 5 ia 


| ByteCountLow Pn 
Byte Count HIG. = [ie = | 
| Device | obs | —na_|{ obs | DEV | ma [| na | na | na_| 
| Status | BSY | DRDY | DF | SERV | DRQ | na | na _ {CHK _| 


Error register - 

Sense Key is a command packet set specific error indication. 

ABRT shall be set to one if the requested command has been command aborted because the 
command code or a command parameter is invalid. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 

EOM - the meaning of this bit is command set specific. See the appropriate command set standard 
for the definition of this bit. 

ILI - the meaning of this bit is command set specific. See the appropriate command set standard for 
the definition of this bit. 

Interrupt reason register - 

Tag - If the device supports command queuing and overlap is enabled, this field contains the 
command Tag for the command. A Tag value may be any value between O and 31 
regardless of the queue depth supported. If the device does not support command queuing 
or overlap is disabled, this field is not applicable. 
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REL - Shall be cleared to zero. 
I/O - Shall be set to one. 
C/D - Shall be set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SERV (Service) - Shall be set to one if another command is ready to be serviced. If overlap is not 
supported, this bit is command specific. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
CHK shall be set to one if an Error register sense key or code bit is set. 


6.25.7 Prerequisites 
This command shall be accepted regardless of the state of DRDY. 
6.25.8 Description 


The PACKET command is used to transfer a device command via a command packet. If the native form of 
the encapsulated command is shorter than the packet size reported in bits (1:0) of word 0 of the IDENTIFY 
PACKET DEVICE response, the encapsulated command shall begin at byte O of the packet. Packet bytes 
beyond the end of the encapsulated command are reserved. 


If the device supports overlap, the OVL bit is set to one in the Features register and the Release interrupt 
has been disabled via the SET FEATURES command, the device may or may not perform a bus release. If 
the device is ready for the data transfer, the device may begin the transfer immediately as described in the 
non-overlapped protocol (See Clause 11). If the data is not ready, the device may perform a bus release and 
complete the transfer after the execution of a SERVICE command. 
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6.26 READ BUFFER 
6.26.1 Command code 
E4h 

6.26.2 Feature set 
General feature set 


— Optional for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.26.3 Protocol 


PIO data-in (See Clause 11). 


6.26.4 Inputs 


| Register | 7] OT ST a 
1” 


Device register - 
DEV shall specify the selected device. 


6.26.5 Normal outputs 


| Register | 7] | 6 OT A a tt 


Bsy_[| DRDY | DF | ona | ORQ [na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.26.6 Error outputs 


The device shall return command aborted if the command is not supported. 
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| Register | 7 | 6 CT TT a 


| Status | BSY [| DRDY [| DF | na | ORQ | na | na _{ ERR | 


Error register - 
ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.26.7 Prerequisites 

DRDY set to one. The command prior to aREAD BUFFER command shall be a WRITE BUFFER command. 
6.26.8 Description 

The READ BUFFER command enables the host to read the current contents of the device’s sector buffer. 


The READ BUFFER and WRITE BUFFER commands shall be synchronized such that sequential WRITE 
BUFFER and READ BUFFER commands access the same 512 bytes within the buffer. 
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6.27 READ DMA 
6.27.1 Command code 
C8h 

6.27.2 Feature set 
General feature set 


— Mandatory for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.27.3 Protocol 
DMA (See Clause 11). 


6.27.4 Inputs 


| Register | 7] OT ST a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA, 
DEV shall specify the selected device. 
Bits (3:0) shall be starting LBA bits (27:24). 


6.27.5 Normal outputs 


| Register | 7] | 6 OT a 


Bsy_ | DRDY | DF | ona _ | ORQ [ na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
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BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.27.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register | 7 |] 6 | | a a ft 
P| Error =| ICRC [| UNC [| MC _ | IDNF | MCR | ABRT | NM | obs | 
| Sector Count fg 


LBA (3:16) 
| Status | BSY | DRDY | DF | na_ [| DRQ [ na _[_na_[ ERR | 


Error register - 
ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 
UNC shall be set to one if data is uncorrectable 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 
ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 
NM shall be set to one if no media is present in a removable media device. 
LBA Low, LBA Mid, LBA High, Device - 

shall be written with the address of first unrecoverable error. 
Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one; however, if SE is set to one, ERR shall 

be cleared to zero. 


6.27.7 Prerequisites 
DRDY set to one. The host shall initialize the DMA channel. 
6.27.8 Description 


The READ DMA command allows the host to read data using the DMA data transfer protocol. 
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6.28 READ DMA EXT 
6.28.1 Command code 
25h 

6.28.2 Feature set 

48-bit Address feature set 


— Mandatory for devices implementing the 48-bit Address feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.28.3 Protocol 
DMA (See Clause 11). 


6.28.4 Inputs 


a Oe A ee 
Features Current Reserved 
Previous Reserved 
Sector Count | Current Sector count (7:0) 
Previous Sector count (15:8) 
LBA Low Current LBA (7:0) 
Previous 
LBA Mid Current LBA (15:8) 
Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). O000h in the Sector Count register 
specifies that 65,536 sectors are to be transferred. 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device -. 
DEV shall specify the selected device. 
LBA bit shall be set to 1 
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6.28.5 Normal outputs 


pRegister CT a Bt 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.28.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


a ee ee ee ee ee 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 
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Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

-LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 

LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 

LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one; however, if SE is set to one, ERR shall 
be cleared to zero. 

6.28.7 Prerequisites 


DRDY set to one. The host shall initialize the DMA channel. 
6.28.8 Description 


The READ DMA EXT command allows the host to read data using the DMA data transfer protocol. 
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6.29 READ DMA QUEUED 
6.29.1 Command code 
C7h 
6.29.2 Feature set 
Overlapped feature set 
— Mandatory for devices implementing the Overlapped feature set and not implementing the PACKET 
Command feature set. 
— Use prohibited for devices implementing the PACKET command feature set. 
6.29.3 Protocol 
DMA QUEUED (See Clause 11). 


6.29.4 Inputs 


| Register | 7] OT 6 OT ST a Tt 
Sector Count 
| ss SectorCount_ | ag Sa | nk Sti 


LBA Mid LBA ie 8) 
LBA High LBA (23:16) 
| CiDevice CSTs, S| ~LBA | obs | DEV | LBA (27:24) 
P Command 


Features - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
Sector count - 
if the device supports command queuing, bits (7:3) contain the Tag for the command being 
delivered. A Tag value may be any value between O and 31 regardless of the queue depth 
supported. If queuing is not supported, this register shall be set to the value OOh. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
Bits (3:0) starting LBA bits (27:24). 


6.29.5 Normal outputs 
6.29.5.1 Data transmission 
Data transfer may occur after receipt of the command or may occur after the receipt of a SERVICE 


command. When the device is ready to transfer data requested by a data transfer command, the device sets 
the following register content to initiate the data transfer. 
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| Register | 7] 6 OT TT a 
p= Ss EO = a I | 
| Ss SectorCount_ | ag REL | VOT CC 
Pp LBALOw Pa 


Pp LBAMig Pa 
la ees SPE GAN ne cr a ne es oe ee Pd 
| Device | bs | Sna_{ obs | DEV | ma [| na _| na | na_| 
| Status | BSY | DRDY | DF | SERV | DRQ | na | na _ {CHK _| 


Sector Count register - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be set to one indicating the transfer is to the host. 
C/D - Shall be cleared to zero indicating the transfer of data. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY - Shall be cleared to zero. 
DRDY - Shall be set to one. 
DF (Device Fault) - Shall be cleared to zero. 
SERV (Service) - Shall be set to one if another command is ready to be serviced. 
DRQ - Shall be set to one. 
CHK - Shall be cleared to zero. 


6.29.5.2 Bus release 


If the device performs a bus release before transferring data for this command, the register content upon 
performing a bus release shall be as shown below. 


| Register | 7] OT ST a 
[mm re a es ek ee eee 
| ss SectorCount_ | ag REL | WOT CC 
Pp LBALow Pn 


| —_EBA Mid fg 
[Device [aos na [obs [bev [r/ 
| Status | BSY_ | DRDY [| DF | SERV | DRQ | na | _na_{ ERR _| 


Sector Count register - 

Tag - If the device supports command queuing, this field shall contain the Tag of the command being 
bus released. If the device does not support command queuing, this field shall be set to the 
value OOh. 

REL shall be set to one. 

I/O shall be zero. 

C/D shall be zero. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating bus release. 

DRDY shall be set to one. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. SERV shall be set 
to one when the device has prepared this command for service. 

DF (Device Fault) shall be cleared to zero. 

DRQ bit shall be cleared to zero. 
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ERR bit shall be cleared to zero. 
6.29.5.3 Service request 


When the device is ready to transfer data or complete a command after the command has performed a bus 
release, the device shall set the SERV bit and not change the state of any other register bit (See Clause 10). 
When the SERVICE command is received, the device shall set outputs as described in data transfer, 
command completion, or error outputs depending on the service the device requires. 


6.29.5.4 Command completion 


When the transfer of all requested data has occurred without error, the register content shall be as shown 
below. 


| Register | 7 OT 6 OT a 
= =~, JEWOR-— = SE Sn 0 te eee 
| ss SectorCount_ [| ag REL | WO | CCC 
Pp LBALow Pn 


| EBA Mi fg 
[Device | obs _[_na_[_obs [DEV [ra 
| Status | BSY_ | DRDY [| DF_ | SERV | DRQ | na | na_[ ERR | 


Sector Count register - 

Tag - If the device supports command queuing, this field shall contain the Tag of the completed 
command. If the device does not support command queuing, this field shall be set to the 
value OOh. 

REL shall be cleared to zero. 

I/O shall be set to one. 

C/D shall be set to one. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 

DF (Device Fault) shall be cleared to zero. 

DRQ bit shall be cleared to Zero. 

ERR bit shall be cleared to zero. 


6.29.6 Error outputs 


The Sector Count register contains the Tag for this command if the device supports command queuing. The 
device shall return command aborted if the command is not supported or if the device has not had 
overlapped interrupt enabled. The device shall return command aborted if the device supports command 
queuing and the Tag is invalid. An unrecoverable error encountered during the execution of this command 
results in the termination of the command and the Command Block registers contain the sector where the 
first unrecoverable error occurred. If a queue existed, the unrecoverable error shall cause the queue to abort. 
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| Register | 7 | 6 CT TT a 
LBA Low 


| Status | BSY_ | DRDY | DF | SERV | DRQ | na | na | ERR | 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if ABRT is not set 
to one. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

Sector Count register - 

Tag - If the device supports command queuing, this field shall contain the Tag of the completed 
command. If the device does not support command queuing, this field shall be set to the 
value OOh. 

REL shall be cleared to zero. 

I/O shall be set to one. 

C/D shall be set to one. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.29.7 Prerequisites 
DRDY set to one. The host shall initialize the DMA channel. 
6.29.8 Description 


This command executes in a similar manner to a READ DMA command. The device may perform a bus 
release or may execute the data transfer without performing a bus release if the data is ready to transfer. 
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6.30 READ DMA QUEUED EXT 
6.30.1 Command code 

26h 

6.30.2 Feature set 


48-bit Address feature set 
— Mandatory for devices implementing the Overlapped feature set and the 48-bit Address feature 
set and not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET command feature set. 


6.30.3 Protocol 
DMA QUEUED (See Clause 11). 


6.30.4 Inputs 


Registers = = ie 8 re 
Features Current Sector count (7:0) 

Previous Sector count (15:8) 

Sector Count Current Reserved 

Previous Reserved 

LBA Low Current LBA (7:0) 

Previous LBA (31:24) 

LBA Mid Current LBA (15:8) 

Previous LBA (39:32) 

LBA High Current LBA (23:16) 

Previous LBA (47:40) 


26h 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Features Current - 
number of sectors to be transferred low order, bits (7:0). 
Features Previous - 
number of sectors to be transferred high order, bits (15:8). O000h in the Features register specifies that 
65,536 sectors are to be transferred. 


Sector Count Current - 
if the device supports command queuing, bits (7:3) contain the Tag for the command being 
delivered. A Tag value may be any value between O and 31 regardless of the queue depth 
supported. If queuing is not supported, this register shall be set to the value OOh. 
Sector Count Previous - 
Reserved 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
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LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
DEV shall specify the selected device. 
LBA shall be set to one 


6.30.5 Normal outputs 
6.30.5.1 Data transmission 


Data transfer may occur after receipt of the command or may occur after the receipt of a SERVICE 
command. When the device is ready to transfer data requested by a data transfer command, the device sets 
the following register content to initiate the data transfer. 


PREGIStGh <= Ss ei Ie SG Wi Bei a ee ses Ue ahi 
Sector Count | HOB =0 Tag REL /O C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when the HOB bit of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be set to one indicating the transfer is to the host. 
C/D - Shall be cleared to zero indicating the transfer of data. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.30.5.2 Bus release 


If the device performs a bus release before transferring data for this command, the register content upon 
performing a bus release shall be as shown below. 
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pRegister CU CZ UT UT A 
Sector Count | HOB = 0 Tag REL /0 C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when the HOB bit of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 

REL - Shall be set to one. 

I/O - Shall be set to one indicating the transfer is to the host. 

C/D - Shall be cleared to zero indicating the transfer of data. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. SERV shall be set 
to one when the device has prepared this command for service. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.30.5.3 Service request 

When the device is ready to transfer data or complete a command after the command has performed a bus 
release, the device shall set the SERV bit and not change the state of any other register bit (See Clause 10). 
When the SERVICE command is received, the device shall set outputs as described in data transfer, 
command completion, or error outputs depending on the service the device requires. 


6.30.5.4 Command completion 


When the transfer of all requested data has occurred without error, the register content shall be as shown 
below. 
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pRegister Cd CZ UT UT A 2 
Sector Count | HOB = 0 Tag REL /0 C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when the HOB bit of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
O and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be set to one. 
C/D - Shall be set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.30.6 Error outputs 


The Sector Count register contains the Tag for this command if the device supports command queuing. The 
device shall return command aborted if the command is not supported or if the device has not had 
overlapped interrupt enabled. The device shall return command aborted if the device supports command 
queuing and the Tag is invalid. An unrecoverable error encountered during the execution of this command 
results in the termination of the command and the Command Block registers contain the sector where the 
first unrecoverable error occurred. If a queue existed, the unrecoverable error shall cause the queue to abort. 
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[Register | TT 8 a 
Sector Count | HOB = 0 Tag REL /0 C/D 
HOB = 1 Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

Sector Count (when the HOB bit of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 

REL - Shall be cleared to zero. 

I/O - Shall be set to one. 

C/D - Shall be set to one. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
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BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 

6.30.7 Prerequisites 

DRDY set to one. The host shall initialize the DMA channel. 

6.30.8 Description 


This command executes in a similar manner to a READ DMA command. The device may perform a bus 
release or may execute the data transfer without performing a bus release if the data is ready to transfer. 
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6.31 READ LOG EXT 
6.31.1 Command code 
2Fh 
6.31.2 Feature set 
General Purpose Logging feature set 
- Mandatory for devices implementing the General Purpose Logging feature set 
6.31.3 Protocol 
PIO data-in (See Clause 11) 


6.31.4 Inputs 
| CRegister_ | 7 |] 6 fT 5 | 4A | 3 UT 2 a 
Features Current Reserved 
PRN | eremus | Resend 
Previous Sector count (15:8) 
LBA Low Current Log address 
a 


LBA Mid Current Sector offset (7:0) 

pMPAMM [remus | Serer) 
LBA High Current Reserved 

| obs | ona | obs [| DEV | Reserved 


NOTE - The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count - Specifies the number of sectors to be read from the specified log. The log transferred by the 
drive shall start at the sector in the specified log at the specified offset, regardless of the sector count 
requested. 

LBA Low - Specifies the log to be returned as described in Table 20. A device may support a subset of the 
available logs. Support for individual logs is determined by support for the associated feature set. 
Support of the associated log(s) is mandatory for devices implementing the associated feature set. 
The host vendor specific logs may be used by the host to store any data desired. If a host vendor 
specific log has never been written by the host, when read the content of the log shall be zeros. 
Device vendor specific logs may be used by the device vendor to store any data and need only be 
implemented if used. 

LBA Mid - Specifies the first sector of the log to be read. 

Device/Head register - 

DEV shall indicate the selected device. 
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Table 20 - Log address definition 


POOH | kogdirectory | ma | ROT 
| 03h_|__Extended Comprehensive SMART errorlog [| SMART errorlogging | = RO__| 
| 07h | Extended SMART self-testlog | SMART self-test_ [|= RO 
| 10h-17h_—| SC ReservedforSerial ATA 
| 20h | Streamingperformancelog | Streaming | RO 
| ah | Write streamerrorlog | Streaming | RO 
| 22h | CReadstreamerrorlog | Streaming =| RO 
| 23h | Celayed'sectorlog | General Purpose Logging |__ RO __| 
| 2a4n-7Fh | Reserved ta ts Reserved | 
SMART 

Key — 

RO - Log is read only by the host. 

R/W - Log is read or written by the host. 

VS - Log is vendor specific thus read/write ability is vendor specific. 


NOTE - If log address 02h or log address O6h are accessed using the READ LOG EXT or WRITE LOG 
EXT commands, command abort shall be returned. 


The Comprehensive SMART error log and the SMART self-test log are defined in 6.54.6 and 6.54.8. If log 
address 02h or log address 06h are accessed using the READ LOG EXT or WRITE LOG EXT commands, 
command abort shall be returned. 


All 28-bit entries contained in the Comprehensive SMART log shall also be included in the Extended 
Comprehensive SMART error log with the 48-bit entries. 


The Extended SMART self-test log sector shall support 48-bit and 28-bit addressing. All 28-bit entries 


contained in the SMART self-test log sector shall also be included in the Comprehensive SMART self-test 
log sector with the 48-bit entries. 
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6.31.5 Normal outputs 


[Register | 7 UT UT CUT 4 | 2 tT 
ee ae Ns ee 


na 
HOB=1 Reserved 
HOB=1 Reserved 
HOB=1 Reserved 


LBA High HOB =0 Reserved 
al HOB = 1 Reserved 
| Status | BSY | DRDY[ DF | na | DRQ [ na _ | na | ERR | 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 


cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device/Head register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.31.6 Error outputs 
If the device does not support this command, if the feature set associated with the log specified in the LBA 


Low register is not supported or enabled, or if the values in the Features, Sector Count, LBA Mid, or LBA 
High registers are invalid, the device shall return command aborted. 


pRegister | GT a 


HOB=1 Reserved 
HOB =1 Reserved 
HOB=1 Reserved 


HOB = 1 Reserved 
| Status, | BSY | DRDY [| DF | na_| DRQ [| na _ | na _| ERR | 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 


cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
UNC shall be set to one if the log contains one or more sectors that are uncorrectable. 
IDNF shall be set to one if the log sector’s ID field was not found or data structure checksum error 
occurred. 

ABRT shall be set to one if this command is not supported, if the feature associated with the log specified in 
the LBA Low register is not supported, or if other register values are invalid. ABRT may be set to 
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one if the device is not able to complete the action requested by the command. ABRT shall be set to 
one if the Sector Count register contains a count larger than the log size reported in the Log 
Directory. ABRT shall be set to one if the host issues a READ LOG EXT or WRITE LOG EXT 
command with a value of zero in the Sector Count register. 


Device/Head register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be set to one indicating that a device fault has occurred. 
DRQ shall be cleared to zero indicating that there is no data to be transferred. 
ERR shall be set to one if any Error register bit is set to one. 


6.31.7 Prerequisites 
DRDY set to one. 
6.31.8 Description 


This command returns the specified log to the host. The device shall interrupt for each DRQ block 
transferred. See 6.54.6. 


6.31.8.1 General Purpose Log Directory 
Table 21 defines the 512 bytes that make up the General Purpose Log Directory. 


Table 21 - General Purpose Log Directory 


Number of sectors in the log at log address 02h (15:8) 
poets IN oe ee ee te 


10h sectors in the log at log address 80h 
00h sectors in the log at log address 80h 
legs Sefer et eo ee ee ee 


510-511 | Number of sectors in the log at log address FFh 


The value of the General Purpose Logging Version word shall be 0001h. A value of 0000h indicates that no 
General Purpose log Directory exists. 


The logs at log addresses 80-9Fh shall each be defined as 16 sectors long. 
6.31.8.2 Extended Comprehensive SMART Error log 


Table 22 defines the format of each of the sectors that comprise the Extended Comprehensive SMART error 
log. The maximum size of the Extended Comprehensive SMART error log is 65,536 sectors. Devices may 
support fewer than 65,535 sectors. All multi-byte fields shown in this structure follow the byte ordering 
described in Volume 1, Clause 3. Error log data structures shall include UNC errors, IDNF errors for which 
the address requested was valid, servo errors, write fault errors, etc. Error log data structures shall not 
include errors attributed to the receipt of faulty commands such as command codes not implemented by the 
device or requests with invalid parameters or invalid addresses. 


All 28-bit entries contained in the Comprehensive SMART log, defined under section 6.54.6.8.3, shall also be 
included in the Extended Comprehensive SMART error log with the 48-bit entries. 
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Table 22 - Extended Comprehensive SMART error log 
0 SMART error log version Reserved 

Reserved Reserved 

Error log index (7:0) Reserved 

Error log index (15:8) Reserved 

4-127 First error log data structure Data structure 4n+1 


128-251 Second error log data structure | Data structure 4n+2 
252-375 Third error log data structure Data structure 4n+3 
376-499 Fourth error log data structure Data structure 4n+4 
500-501 Device error count Reserved 
502-510 Reserved Reserved 

511 Data structure checksum Data structure checksum 


n is the sector number within the log. The first sector is sector zero 


6.31.8.2.1 Error log version 
The value of the SMART error log version byte shall be 01h. 
6.31.8.2.2 Error log index 


The error log index indicates the error log data structure representing the most recent error. If there have 
been no error log entries, the error log index is cleared to zero. Valid values for the error log index are zero 
to 65,536. 


6.31.8.2.3 Extended Error log data structure 


The error log is viewed as a circular buffer. When the last supported error log sector has been filled, the next 
error shall create an error log data structure that replaces the first error log data structure in sector zero. The 
next error after that shall create an error log data structure that replaces the second error log data structure 
in sector zero. The fifth error after the log has filled shall replace the first error log data structure in sector 
one, and so on. 


The error log index indicates the most recent error log data structure. Unused error log data structures shall 
be filled with zeros. 


The content of the error log data structure entries is defined in Table 23. 


Table 23 - Extended Error log data structure 


n+54 thru n+71 Fourth command data structure 
n+72 thru n+89 Fifth command data structure 
n+90 thru n+123 Error data structure 


6.31.8.2.3.1 Command data structure 


The fifth command data structure shall contain the command or reset for which the error is being reported. 
The fourth command data structure should contain the command or reset that preceded the command or 
reset for which the error is being reported, the third command data structure should contain the command or 
reset preceding the one in the fourth command data structure, etc. If fewer than four commands and resets 
preceded the command or reset for which the error is being reported, the unused command data structures 
shall be zero filled, for example, if only three commands and resets preceded the command or reset for 
which the error is being reported, the first command data structure shall be zero filled. In some devices, the 
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hardware implementation may preclude the device from reporting the commands that preceded the 
command for which the error is being reported or that preceded a reset. In this case, the command data 
structures are zero filled. 


If the command data structure represents a command or software reset, the content of the command data 
structure shall be as shown in Table 24. If the command data structure represents a hardware reset, the 
content of byte n shall be FFh, the content of bytes n+1 through n+13 are vendor specific, and the content of 
bytes n+14 through n+17 shall contain the timestamp. 


Table 24 - Command data structure 


| Byte | Descriptions 
Content of the Device Control register when the Command register was written. 


Content of the Features register (7:0) when the Command register was written. (See note 
Content of the Features register (15:8) when the Command register was written. 

Content of the Sector Count register (7:0) when the Command register was written. 
Content of the Sector Count register (15:8) when the Command register was written. 


NOTE - bits (7:0) refer to the most recently written contents of the register. Bits (15:8) refer to the 
contents of the register prior to the most recent write to the register. 


Timestamp shall be the time since power-on in milliseconds when command acceptance occurred. This 
timestamp may wrap around. 


6.31.8.2.3.2 Error data structure 
The error data structure shall contain the error description of the command for which an error was reported 


as described in Table 25. If the error was logged for a hardware reset, the content of bytes n+1 through n+11 
shall be vendor specific and the remaining bytes shall be as defined in Table 25. 
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Table 25 - Error data structure 


| Byte [Descriptions 


n+12 Extended error information 
through 
n+30 


NOTE - bits (7:0) refer to the contents if the register were read with bit 7 of the Device Control register 
cleared to zero. Bits (15:8) refer to the contents if the register were read with bit 7 of the Device 
Control register set to one. 


Extended error information shall be vendor specific. 


State shall contain a value indicating the state of the device when the command was written to the Command 
register or the reset occurred as described in Table 26. 


Table 26 - State field values 


[Value | State 


Active/idle with BSY cleared to zero 


xSh-xAh 
xBh-xFh Vendor unique 


The value of x is vendor specific and may be different for each state. 


Sleep indicates the reset for which the error is being reported was received when the device was in the 
Sleep mode. 


Standby indicates the command or reset for which the error is being reported was received when the device 
was in the Standby mode. 


Active/Idle with BSY cleared to zero indicates the command or reset for which the error is being reported was 
received when the device was in the Active or Idle mode and BSY was cleared to zero. 


Executing SMART off-line or self-test indicates the command or reset for which the error is being reported 
was received when the device was in the process of executing a SMART off-line or self-test. 


Life timestamp shall contain the power-on lifetime of the device in hours when command completion 
occurred. 
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6.31.8.2.4 Device error count 


The device error count field shall contain the total number of errors attributable to the device that have been 
reported by the device during the life of the device. These errors shall include UNC errors, IDNF errors for 
which the address requested was valid, servo errors, write fault errors, etc. This count shall not include errors 
attributed to the receipt of faulty commands such as commands codes not implemented by the device or 
requests with invalid parameters or invalid addresses. If the maximum value for this field is reached, the 
count shall remain at the maximum value when additional errors are encountered and logged. 


6.31.8.2.5 Data structure checksum 


The data structure checksum is the two’s complement of the sum of the first 511 bytes in the data structure. 
Each byte shall be added with unsigned arithmetic, and overflow shall be ignored. The sum of all 512 bytes 
will be zero when the checksum is correct. The checksum is placed in byte 511. 


6.31.8.3 Extended Self-test log sector 


Table 27 defines the format of each of the sectors that comprise the Extended SMART Self-test log. The 
maximum size of the self-test log is 65,535 sectors. Devices may support fewer than 65,536 sectors. All 
multi-byte fields shown in this structure follow the byte ordering described in Volume 1, Clause 3. 


The Extended SMART self-test log sector shall support 48-bit and 28-bit addressing. All 28-bit entries 
contained in the SMART self-test log, defined under section 6.54.6.8.4 shall also be included in the Extended 
SMART self-test log with all 48-bit entries. 


Table 27 - Extended Self-test log data structure 
0 Self-test log data structure revision number Reserved 
Reserved Reserved 
Self-test descriptor index (7:0) Reserved 
Self-test descriptor index (15:8) Reserved 
4-29 Descriptor entry 1 Descriptor entry 18n+1 
30-55 Descriptor entry 2 Descriptor entry 18n+2 


472-497 Descriptor entry 18 Descriptor entry 18n+18 
498-499 Vendor specific Vendor specific 
500-510 Reserved Reserved 

511 Data structure checksum Data structure checksum 


n is the sector number within the log. The first sector is sector zero 


This log is viewed as a circular buffer. When the last supported Self-test log sector has been filled, the next 
self-test shall create a descriptor that replaces descriptor entry 1 in sector 0. The next self-test after that 
shall create a descriptor that replaces descriptor entry 2 in sector 0, and so on. All unused self-test 
descriptors shall be filled with zeros. 

6.31.8.3.1 Self-test descriptor index 


The Self-test descriptor index indicates the most recent self-test descriptor. If there have been no self-tests, 
the Self-test descriptor index is set to zero. Valid values for the Self-test descriptor index are zero to 65,535. 


6.31.8.3.2 Self-test log data structure revision number 


The value of the self-test log data structure revision number shall be 01h. 
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6.31.8.3.3 Extended Self-test log descriptor entry 


The content of the self-test descriptor entry is shown in Table 28. 


Table 28 - Extended Self-test log descriptor entry 
po ntS | FailingLBA (7:0), 


n+5 Failing LBA (7:0). 
n+1 -n+23 


Content of the LBA Low register shall be the content of the LBA Low register when the nth self-test 
subcommand was issued (See 6.54.4.8). 


Content of the self-test execution status byte shall be the content of the self-test execution status byte when 
the nth self-test was completed (See 6.54.5.10). 


Life timestamp shall contain the power-on lifetime of the device in hours when the nth self-test subcommand 
was completed. 


Content of the self-test failure checkpoint byte may contain additional information about the self-test that 
failed. 


The failing LBA shall be the LBA of the sector that caused the test to fail. If the device encountered more 
than one failed sector during the test, this field shall indicate the LBA of the first failed sector encountered. If 
the test passed or the test failed for some reason other than a failed sector, the value of this field is 
undefined. 


6.31.8.3.4 Data structure checksum 


The data structure checksum is the two's complement of the sum of the first 511 bytes in the data structure. 
Each byte shall be added with unsigned arithmetic, and overflow shall be ignored. The sum of all 512 bytes 
is zero when the checksum is correct. The checksum is placed in byte 511. 


6.31.8.4 Read Stream Error Log 


Table 29 defines the format of the Read Stream Error log. Entries are placed into the Read Stream Error log 
only when the SE bit is set to one in the Status register. The 512 bytes returned shall contain a maximum of 
31 error entries. The Read Stream Error Count shall contain the total number of Read Stream Errors 
detected since the last successful completion of the READ LOG EXT command with LBA Low register set to 
22h. This error count may be greater than 31, but only the most recent 31 errors are represented by entries 
in the log. If the Read Stream Error Count reaches the maximum value that can be represented, after the 
next error is detected the Read Stream Error Count shall remain at the maximum value. After successful 
completion of a READ LOG EXT command with the LBA Low Register set to 22h, the Read Stream Error 
Log shall be reset to a power-on or hardware reset condition, with the Error Log Index and Read Stream 
Error Count cleared to zero. The Read Stream Error Log is not preserved across power cycles and hardware 
reset. 
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Table 29 - Read Stream Error Log 
Content 
Structure Version 
Error Log Index 
Read Stream Error Log Count 
Reserved 
Read Stream Error Log Entry #1 
Read Stream Error Log Entry #2 
Read Stream Error Log Entry #3 
Read Stream Error Log Entries #4 through #31 


The Data Structure Version field shall contain a value of 02h indicating the second revision of the structure 
format. 


The Read Stream Error Log Count field shall contain the number of uncorrected sector entries currently 
reportable to the host. This value may exceed 31. 


The Error Log Index indicates the error log data structure representing the most recent error. Only values 
(31:1) are valid. 


Table 30 defines the format of each entry in the Read Stream Error Log. 


Table 30 - Error Log Entr 
Byte 
| CCC“ eT Feaature Register Contents Value (current) 
PBA (89:32) 


LBA (39:32) 


Reserved 


Byte (1:0) (Feature Register Contents Value) contains the contents of the Feature Register when the error 
occurred. This value shall be set to OFFFFh for a deferred write error. 


Byte 2 (Status Register Contents Value) contains the contents of the Status Register when the error 
occurred. 


Byte 3 (Error Register Contents Value) contains the contents of the Error Register when the error occurred. 
Bytes (9:4) (LBA) indicate the starting LBA of the error. 


Bytes (13:12) (Sector Count) indicate the length of the error. Therefore, each entry may describe a range of 
sectors starting at the given address and spanning the specified number of sectors. 


6.31.8.5 Write Stream Error Log 


Table 31 defines the format of the Write Stream Error log. Entries are placed into the Write Stream Error log 
only when the SE bit is set to one in the Status register. The 512 bytes returned shall contain a maximum of 
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31 error entries. The Write Stream Error Count shall contain the total number of Write Stream Errors 
detected since the last successful completion of the READ LOG EXT command with LBA Low register set to 
21h. This error count may be greater than 31, but only the most recent 31 errors are represented by entries 
in the log. If the Write Stream Error Count reaches the maximum value that can be represented, after the 
next error is detected the Write Stream Error Count shall remain at the maximum value. After successful 
completion of a READ LOG EXT command with the LBA Low Register set to 21h, the Write Stream Error 
Log shall be reset to a power-on or hardware reset condition, with the Error Log Index and Write Stream 
Error Count cleared to zero. The Write Stream Error Log is not preserved across power cycles and hardware 
reset. 


Table 31 - Write Stream Error Log 
Content 


Structure Version 

Error Log Index 

Write Stream Error Log Count 
Reserved 


Reserved 

Write Stream Error Log Entry #1 

Write Stream Error Log Entry #2 

Write Stream Error Log Entry #3 

Write Stream Error Log Entries #4 through #31 


The Data Structure Version field shall contain a value of 02h indicating the second revision of the structure 
format. 


The Write Stream Error Log Count field shall contain the number of WRITE STREAM command entries since 
the last power on, since this log was last read, or since a hardware reset was executed. 


The Error Log Index indicates the error log data structure representing the most recent error. Only values 
(31:0) are valid. 


Table 30 defines the format of each entry in the Error Log. 

6.31.8.6 Streaming Performance Log 

Table 32, Table 33, Table 34, and Table 35 define the format of the log returned by the READ LOG EXT 
command, when the LBA Low register is 20h. This data set is referred to as the Streaming Performance 
Parameters log, the length of which (in sectors) is statically indicated in READ LOG EXT log address OOh 
(Log Directory). 


The contents of Streaming Performance Parameters Log may be affected by the host issuing a SET 
FEATURES subcommand 42h, C2h, or 43h and may also affect the Delayed LBA log. 


NOTE -— The host should check the content of the Streaming Performance Parameters log and the Delayed 
LBA log after issuing SET FEATURES subcommands 42h, 43h, or C2h. 


The host should base its calculations on the larger of its Typical Host Interface Sector Time and the device 


reported Sector Time values, and on the sum of the device reported Access Time values and any additional 
latency that only the host is aware of (e.g., host command overhead, etc). 
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Table 32 - Streaming Performance Parameters Log 
Stream Performance Parameters log version 


K, Number of Regions in Sector Time Array 
L, Number of Positions in Position Arra 


Table 33 - Sector Time Array Entry (Linearly Interpolated) 
Logical Block Address of reference location (LBA(7:0)...LBA(47:40)) 


(n+6)-(n+7) (IDENTIFY DEVICE data words (99:98))/65536 time units per sector at 
the reference location 


Table 34 - Position Array Entry (Linearly Interpolated) 


| Byte | Descriptions 
Logical Block Address of start of region (LBA(7:0)...LBA(47:40)) 
(n+6)-(n+7) Position number in the range 0...32767 


Table 35 - Access Time Array Entry (Linearly Interpolated) 
Difference in position from last stream access to new stream access 


(n+2)-(n+3) Time that may be required to begin access at new stream access 
position, in (IDENTIFY DEVICE data words (89:88))/256 time units. 


6.31.8.7 Delayed LBA Log 


Table 36 defines the format of each of the sectors that comprise the Delayed LBA Log. The maximum size of 
the Delayed LBA Log is vendor specific. The alternate physical location, access method, or access time for a 
Delayed LBA are vendor specific. 


If the maximum size of the Delayed LBA Log is reached and an additional Delayed LBA is detected by the 
device, the most recent Delayed LBA shall not be added to the log. 


The device may add entries to the log at any time. The device shall not remove entries from this log. The 
log is returned to the host ordered by timestamp, the most recently added entry is last. 


The Delayed LBA Log is non-volatile, it is preserved across power cycles and hardware reset. 
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Table 36 - Delayed LBA log 


|} _0__| _Delayed LBA Log Version _{ _Reserved 
Reserved 
4-9 LBA of (63n+1) Delayed LBA 
Life Timestamp (7:0) of (63n+1) Delayed LBA 


Life Timestamp (15:8) of 1° Delayed Life Timestamp (15:8) of (63n+1) Delayed LBA 
LBA 


12-17 LBA of 2" Delayed LBA LBA of (63n+2) Delayed LBA 


18-19 Life Timestamp of 2™ Delayed LBA Reserved 


LR aa Ca aap en | ee ee eee eee 


n is the sector number within the log. The first sector is sector 0. 


6.31.8.7.1 Delayed LBA Log Version 

The value of the Delayed LBA Log Version shall be set to O1h. 

6.31.8.7.2_ Number of Delayed LBA entries 

The Number of Delayed LBA entries shall contain the total count of Delayed LBA entries, and shall be 
consistent with the number of LBA entries in the Delayed LBA Log. If the maximum value for this field is 
reached (corresponding to the vendor-specific maximum number of sectors in the log), the count shall 
remain at the maximum value when additional Delayed LBA entries are added. 


6.31.8.7.3 Life Timestamp 


The Life Timestamp shall contain the power-on lifetime of the device, in hours, when the sector was entered 
into the log. 
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6.32 READ MULTIPLE 
6.32.1 Command code 
C4h 

6.32.2 Feature set 
General feature set 


— Mandatory for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.32.3 Protocol 
PIO data-in (See Clause 11). 


6.32.4 Inputs 


| Register | 7] OT 6 OT 5 a 


LBA Mid LBA (15:0) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.32.5 Normal outputs 


| Register | 7] | 6 OT a 


Bsy_ [| DRDY | DF | na | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
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DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.32.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register | 7 | 6 CT TT a 


LBA (23:16) 
| Status | BSY [| DRDY [| DF | na _ | ORQ | na | na _{ ERR | 


Error register - 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be. IDNF shall be set to one if an 
address outside of the range of user-accessible addresses is requested if command aborted 
is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.32.7 Prerequisites 


DRDY set to one. If bit 8 of IDENTIFY DEVICE data word 59 is cleared to zero, a successful SET MULTIPLE 
MODE command shall precede a READ MULTIPLE command. 


6.32.8 Description 
This command reads the number of sectors specified in the Sector Count register. 


The number of sectors per block is defined by the content of word 59 in the IDENTIFY DEVICE data. The 
device shall interrupt for each DRQ block transferred. 


When the READ MULTIPLE command is issued, the Sector Count register contains the number of sectors 
(not the number of blocks) requested. 
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If the number of requested sectors is not evenly divisible by the block count, as many full blocks as possible 
are transferred, followed by a final, partial block transfer. The partial block transfer shall be for n sectors, 
where n = remainder (sector count/ block count). 


If the READ MULTIPLE command is received when READ MULTIPLE commands are disabled, the READ 
MULTIPLE operation shall be rejected with command aborted. 


Device errors encountered during READ MULTIPLE commands are posted at the beginning of the block or 
partial block transfer, but the DRQ bit is still set to one and the data transfer shall take place, including 
transfer of corrupted data, if any. The contents of the Command Block Registers following the transfer of a 
data block that had a sector in error are undefined. The host should retry the transfer as individual requests 
to obtain valid error information. 


Subsequent blocks or partial blocks are transferred only if the error was a correctable data error. All other 
errors cause the command to stop after transfer of the block that contained the error. 
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6.33 READ MULTIPLE EXT 

6.33.1 Command code 

29h 

6.33.2 Feature set 

48-bit Address feature set 
— Mandatory for all devices implementing the 48-bit Address feature set. 
— Use prohibited when the PACKET command feature set is implemented 

6.33.3 Protocol 

PIO data-in (See Clause 11). 


6.33.4 Inputs 


[Register i (st—“‘L 7@~C|~ 6h] 6cSULUT hcAmUCUhT 8 UT 2] UT tT 
Features Current Reserved 
Previous Reserved 


Sector Count Current Sector count (7:0) 
Previous Sector count (15:8) 
LBA Low Current LBA (7:0) 
Previous LBA (31:24) 
LBA Mid Current LBA (15:8) 


Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). O000h in the Sector Count register 
specifies that 65,536 sectors are to be transferred. 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
DEV shall specify the selected device. 
LBA shall be set to one 
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6.33.5 Normal outputs 


| Register | 7] dT 6 CT CT 4 | 3 CT 2 a 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 
LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.33.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


[Register | 7 UT CUT LUT aA | sf 2 Ta 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
UNC shall be set to one if data is uncorrectable 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
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MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.33.7 Prerequisites 


DRDY set to one. If bit 8 of IDENTIFY DEVICE data word 59 is cleared to zero, a successful SET MULTIPLE 
MODE command shall precede a READ MULTIPLE EXT command. 


6.33.8 Description 
This command reads the number of sectors specified in the Sector Count register. 


The number of sectors per block is defined by a successful SET MULTIPLE command. If no successful SET 
MULTIPLE command has been issued, the block is defined by the device’s default value for number of 
sectors per block as defined in bits (7:0) in word 47 in the IDENTIFY DEVICE data. The device shall interrupt 
for each DRQ block transferred. 


When the READ MULTIPLE EXT command is issued, the Sector Count register contains the number of 
sectors (not the number of blocks) requested. 


If the number of requested sectors is not evenly divisible by the block count, as many full blocks as possible 
are transferred, followed by a final, partial block transfer. The partial block transfer shall be for n sectors, 
where n = remainder (sector count/ block count). 


If the READ MULTIPLE EXT command is received when READ MULTIPLE commands are disabled, the 
READ MULTIPLE operation shall be rejected with command aborted. 


Device errors encountered during READ MULTIPLE EXT commands are posted at the beginning of the 


block or partial block transfer, but the DRQ bit is still set to one and the data transfer shall take place, 
including transfer of corrupted data, if any. The contents of the Command Block Registers following the 
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transfer of a data block that had a sector in error are undefined. The host should retry the transfer as 
individual requests to obtain valid error information. 


Subsequent blocks or partial blocks are transferred only if the error was a correctable data error. All other 
errors cause the command to stop after transfer of the block that contained the error. 
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6.34 READ NATIVE MAX ADDRESS 
6.34.1 Command code 

F8h 

6.34.2 Feature set 

Host Protected Area feature set. 


— Mandatory when the Host Protected Area feature set is implemented. 
— Use prohibited when Removable feature set is implemented. 


6.34.3 Protocol 
Non-data (See Clause 11). 


6.34.4 Inputs 


| Register | 7] 6 OT ST a tt 
| Features Pa 
| SectorCount, Pm 
Pp LBALow Pm 


| LBAMig Pa 
Fees 27 ee a 
| Device | obs, | LBA | obs | DEV | oma 
| Command 


Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 


6.34.5 Normal outputs 


| CRegister | 7 | 6 CUT CUT Tt 
Pron me 
Native max address LBA (7:0) 


| Status] SY | DRDY | DF | na_ | ORQ | na | na _[ ERR | 


LBA Low - 

maximum native LBA bits (7:0) for native max address on the device. 
LBA Mid - 

maximum native LBA bits (15:8) for native max address on the device. 
LBA High - 

maximum native LBA bits (23:16) for native max address on device. 
Device - 

maximum native LBA bits (27:24) for native max address on the device. 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 
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DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 

6.34.6 Error outputs 


If this command is not supported the device shall return command aborted. 


| Register |] 7 | 6 | a a 
P| Error | na Sf na =O] na—S] SCmat_— | Sna_—] BRT | na | na _| 
+ = Settot Coulton ia 
Pp LBALow 

——— ee 


a a | 
| Status | SY [| DRDY | na | ona | ona | ona | na _{ ERR | 


Error register - 
ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
ERR shall be set to one if an Error register bit is set to one. 


6.34.7 Prerequisites 

DRDY set to one. 

6.34.8 Description 

This command returns the native maximum address. The native maximum address is the highest address 
accepted by the device in the factory default condition. The native maximum address is the maximum 


address that is valid when using the SET MAX ADDRESS command. 


If the 48-bit Address feature set is supported and the 48-bit native max address is greater than 268,435,455, 
the READ NATIVE MAX ADDRESS command shall return a maximum value of 268,435,454. 
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6.35 READ NATIVE MAX ADDRESS EXT 

6.35.1 Command code 

27h 

6.35.2 Feature set 

Host Protected Area feature set and 48-bit Address feature set. 


— Mandatory when the Host Protected Area feature set and the 48-bit Address feature set are 
implemented. 

— Use prohibited when Removable feature set is implemented. 

— Use prohibited when PACKET Command feature set is implemented. 


6.35.3 Protocol 
Non-data (See Clause 11). 


6.35.4 Inputs 


PRegister Cd ZT TB A 2 
Features Current Reserved 

Previous Reserved 

Sector Count Current Reserved 

Previous Reserved 

LBA Low Current Reserved 

Previous Reserved 

LBA Mid Current Reserved 


Previous Reserved 


LBA High Current Reserved 
Previous Reserved 
NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Device register - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.35.5 Normal outputs 


| Register | 7] dT 6 UT CUT 4A | 8 UT 2 a 
a = OO 
Sector Count | HOB =0 Reserved 
LBA Low Native max address LBA (7:0) 
Native max address LBA (31:24) 
LBA Mid = Native max address LBA (15:8) 
Native max address LBA (39:32) 


LBA High Native max address LBA (23:16) 
Native max address LBA (47:40) 


Reserved 
satis psy bey pena DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


LBA Low - 
LBA (7:0) of the address of the Native max address when read with Device Control register HOB bit 
cleared to zero. 
LBA (31:24) of the address of the Native max address when read with Device Control register HOB 
bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the Native max address when read with Device Control register HOB bit 
cleared to zero. 
LBA (39:32) of the address of the Native max address when read with Device Control register 
HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the Native max address when read with Device Control register HOB 
bit cleared to zero. 
LBA (47:40) of the address of the Native max address when read with Device Control register HOB 
bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.35.6 Error outputs 


If this command is not supported the device shall return command aborted. 
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pRegister Cd CZ UT UT A 
Sector Count | HOB =0 Reserved 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
ABRT shall be set to one if this command is not supported. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.35.7 Prerequisites 

DRDY set to one. 

6.35.8 Description 

This command returns the native maximum address. The native maximum address is the highest address 


accepted by the device in the factory default condition. The native maximum address is the maximum 
address that is valid when using the SET MAX ADDRESS EXT command. 
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6.36 READ SECTOR(S) 
6.36.1 Command code 
20h 
6.36.2 Feature set 
General feature set 
— Mandatory for all devices. 
— PACKET Command feature set devices (See 6.36.5.2). 
6.36.3 Protocol 
PIO data-in (See Clause 11). 


6.36.4 Inputs 


| Register | 7 OT ST a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.36.5 Outputs 


6.36.5.1 Normal outputs 


| Register | 7] | 6 OT 5 a 


Bsy_ | DRDY | DF | ona _ | ORQ [ na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
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BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.36.5.2 Outputs for PACKET Command feature set devices 

In response to this command, devices that implement the PACKET Command feature set shall post 
command aborted and place the PACKET Command feature set signature in the LBA High and the LBA Mid 
register (See 5.15). 

6.36.6 Error outputs 

An unrecoverable error encountered during the execution of this command results in the termination of the 


command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register | 7] | ST a 


| Status | BSY [| DRDY | DF [| ona | ORQ | na | na _{ ERR | 


Error register - 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.36.7 Prerequisites 


DRDY set to one. 
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6.36.8 Description 

This command reads from 1 to 256 sectors as specified in the Sector Count register. A sector count of O 
requests 256 sectors. The transfer shall begin at the sector specified in the LBA Low, LBA Mid, LBA High, 
and Device registers. The device shall interrupt for each DRQ block transferred. 


The DRQ bit is always set to one prior to data transfer regardless of the presence or absence of an error 
condition. 
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6.37 READ SECTOR(S) EXT 
6.37.1 Command code 

24h 

6.37.2 Feature set 


48-bit Address feature set 
— Mandatory for all devices implementing the 48-bit Address feature set. 
— Use prohibited when the PACKET command feature set is implemented 


6.37.3 Protocol 
PIO data-in (See Clause 11). 


6.37.4 Inputs 


[Register S| UT UT LT 2 
Features Current Reserved 
Previous Reserved 
Sector Count | Current Sector count (7:0) 
Previous Sector count (15:8) 
LBA Low Current LBA (7:0) 
Previous LBA (31:24) 
LBA Mid Current LBA (15:8) 
Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.37.5 Normal outputs 


[Register S| UT UT UCU A TT 2 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 
LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.37.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


[Register | 7 UT CUT LUT aA | sf 2 Ta 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
UNC shall be set to one if data is uncorrectable 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
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MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.37.7 Prerequisites 

DRDY set to one. 

6.37.8 Description 

This command reads from 1 to 65,536 sectors as specified in the Sector Count register. A sector count of 
0000h requests 65,536 sectors. The transfer shall begin at the sector specified in the LBA Low, LBA Mid, 
and LBA High registers. The device shall interrupt for each DRQ block transferred. 


The DRQ bit is always set to one prior to data transfer regardless of the presence or absence of an error 
condition. 
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6.38 READ STREAM DMA EXT 
6.38.1 Command code 

2Ah 

6.38.2 Feature set 


— Mandatory if the Streaming feature set is implemented. 
— Use prohibited if PACKET Command feature set is implemented. 


6.38.3 Protocol 
DMA (See Clause 11) 


6.38.4 Inputs 


Register —__{|_7—| 6 | sj 4| 3 [2 | 
Features Current URG Stream ID 

Previous Sanaa Completion Tine Limit (7:0) 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current LBA (7:0) 

Previous LBA (31:24) 

LBA Mid Current LBA (15:8) 


Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Features register current - 

URG specifies an urgent transfer request. The Urgent bit specifies that the command should be 
completed in the minimum possible time by the device and shall be completed within the 
specified Command Completion Time Limit. This bit is optional (See 6.17.42). 

RC specifies Read Continuous mode enabled. If the Read Continuous bit is set to one,the device 
shall not stop execution of the command due to errors. 

If thr RC bit is set to one and errors occur in reading or transfer of the data, the device shall 
continue to transfer the amount of data requested and then provide ending status with the BSY 
bit cleared to zero, the SE bit set to one, the ERR bit cleared to zero, and the type of error, 
ICRC, UNC, IDNF, or ABRT, reported in the error log. 

If the RC bit is set to one and the Command Completion Time Limit expires, the device shall stop 
execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit 
set to one, the ERR bit cleared to zero, and report the fact that the Command Completion Time 
Limit expired by setting the CCTO bit in the error log to one. 

In all cases, the device shall attempt to transfer the amount of data requested within the Comand 
Completion Time Limit even if some data transferred is in error. 

NS (Not Sequential) may be set to one if the next read stream command with the same Stream ID 
may not be sequential in LBA space. Any read of the device media or internal device buffer 
management as a result of the state of the NS bit is device vendor specific. 

HSE (Handle Streaming Error) specifies that this command starts at the LBA of the last reported 
error for this stream, so the device may attempt to continue its corresponding error recovery 
sequence where it left off earlier. 

r specifies reserved. 
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Stream ID specifies the stream to be read. The device shall operate according to the Stream ID set 
by the READ STREAM command. Any read of the device media or internal device buffer 
management as a result of the Stream ID is device vendor specific. 

Features register previous - 
The time allowed for the current command’s completion is calculated as follows: 
Command Completion Time Limit = (content of the Features register Previous) 
* (IDENTIFY DEVICE data words (99:98)) microseconds 
If the value is zero, the device shall use the Default Command Completion Time Limit supplied 
with a previous CONFIGURE STREAM command for this Stream ID. If the Default Command 
Completion Time Limit is zero, or no previous Configure Stream command was defined for this 
Stream ID, the result is vendor specific. The time is measured from the write of the command 
register to the final INTRQ for command completion. 
Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
LBA shall be set to one. 
DEV shall specify the selected device. 


6.38.5 Normal Outputs 


fRegister — CUT CT UT CSC DTC U4 UT CT 2 
Sector Count | HOB =0 Reserved 
HOB=1 Reserved 
LBA Low Reserved 


Reserved 
LBA Mid = Reserved 


Reserved 
LBA High Reserved 
Reserved 


Reserved 


Status DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device/Head register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SE (Stream Error) shall be cleared to zero. 
DRQ shall be cleared to zero. 
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ERR shall be cleared to zero. 


6.38.6 Error Outputs 


If the RC bit is cleared to zero, the content of the registers shal be as shown below. If the RC bit is set to 
one, the SE bit shall be set to one, the ERR bit shall be cleared to zero, and the content of the Error register 
shown below shall be placed in the error log. 


pRegister 0 TT a 2 


HOB=1 Length of Stream Error (15:8 
HOB=1 LBA (31:24 
LBA Mid LBA (15:8) 


LBA (39:32) 
LBA High LBA (23:16) 


Reserved 
| Status | BSY | DRDY [| SE | DWE | DRQ | na _[ na _| 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. The 
content of this bit is not applicable for Multiword DMA transfers. 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the last 
command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if an 
address outside of the range of user-accessible addresses is requested if command aborted is not 
returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is not 
able to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

CCTO (Command Completion Time Limit Out) bit shall be set to one if a Command Completion Time 
Limit Out error has occurred. 

Sector Count Current - 

bits (7:0) number of contiguous sectors containing potentially bad data, beginning with the LBA of the 

first sector with an uncorrectable error. 
Sector Count Previous - 

bits (15:8) of the number of contiguous sectors containing potentially bad data, starting at the address of 

the first uncorrectable error 
LBA Low Current - 
bits (7:0) of the address of the first uncorrectable error when read with Device Control register HOB 
cleared to zero. 
LBA Low Previous - 
bits (31:24) of the address of the first uncorrectable error when read with Device Control register HOB 
set to one. 
LBA Mid Current- 
bits (15:8) of the address of the first uncorrectable error when read with Device Control register HOB 
cleared to zero. 
LBA Mid Previous- 
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bits (39:32) of the address of the first uncorrectable error when read with Device Control register HOB 

set to one. 
LBA High Current - 

bits (23:16) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA High Current - 
bits (47:40) of the address of the first uncorrectable error when read with Device Control register HOB 
set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

SE (Stream Error) shall be set to one if an error has occurred during the execution of the command and 
the RC bit is set to one. In this case the LBA returned in the Sector Number registers shall be the 
address of the first sector in error, and the Sector Count registers shall contain the number of 
consecutive sectors that may contain errors. If the RC bit is set to one when the command is issued 
and an ICRC, UNC, IDNF, ABRT, or CCTO error occurs, the SE bit shall be set to one, the ERR bit 
shall be cleared to zero, and the bits that would normally be set in the Error register shall be set in 
the error log. 

DWE (Deferred Write Error) shall be set to one if an error was detected in a deferred write to the media 
for a previous WRITE STREAM DMA EXT or WRITE STREAM EXT command. This error is from a 
previously issued command. If DWE is set to one, the location of the deferred error is only reported 
in the Write Stream error log. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one and the RC bit is cleared to zero. If the RC bit 
is set to one when the command is issued and an ICRC UNC, IDNF, ABRT, or CCTO error occurs, 
the SE bit shall be set to one, the ERR bit shall be cleared to zero, and the bits that would normally 
be set in the Error register shall be set in the error log. 


6.38.7 Prerequisites 
DRDY set to one and BSY cleared to zero. 
6.38.8 Description 


The command reads from 1 to 65536 sectors as specified in the Sector Count register. A value of 0000h in 
the Sector Count register requests 65536 sectors. 


The RC bit indicates that the drive operate in a continuous read mode for the READ STREAM command. 
When RC is cleared to zero the drive shall operate in normal Streaming read mode. 


When the Read Continuous mode is enabled, the device shall transfer data of the requested length without 
setting the ERR bit to one. The SE bit shall be set to one if the data transferred includes errors. The data 
may be erroneous in this case. If an error is encountered, it may be necessary for the device to pad the data 
being transferred in order to fulfill the host’s requested transfer size. The implementation of the padding is 
vendor specific. 


If the Read Continuous bit is set to one,the device shall not stop execution of the command due to errors. If 
thr RC bit is set to one and errors occur in reading or transfer of the data, the device shall continue to 
transfer the amount of data requested and then provide ending status with the BSY bit cleared to zero, the 
SE bit set to one, the ERR bit cleared to zero, and the type of error, ICRC, UNC, IDNF, or ABRT, reported in 
the error log. If the RC bit is set to one and the Command Completion Time Limit expires, the device shall 
stop execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit set to 
one, the ERR bit cleared to zero, and report the fact that the Command Completion Time Limit expired by 
setting the CCTO bit in the error log to one. In all cases, the device shall attempt to transfer the amount of 
data requested within the Comand Completion Time Limit even if some data transferred is in error. 
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6.39 READ STREAM EXT 
6.39.1 Command code 

2Bh 

6.39.2 Feature Set 


— Mandatory if the Streaming feature set is implemented. 
— Use prohibited if PACKET Command feature set is implemented. 


6.39.3 Protocol 
PIO data-in (See Clause 11) 


6.39.4 Inputs 


Register —__{|_7 | @_| sj 4| 3 fe | 
Features Current URG Stream ID 

Previous Sanaa Completion Tine Limit (7:0) 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current LBA (7:0) 

Previous LBA (31:24) 

LBA Mid Current LBA (15:8) 


Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE —- The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Features register current - 

URG specifies an urgent transfer request. The Urgent bit specifies that the command should be 
completed in the minimum possible time by the device and within the specified Command 
Completion Time Limit. This bit is optional (See 6.17.42). 

RC specifies Read Continuous mode enabled. If the Read Continuous bit is set to one,the device shall 
not stop execution of the command due to errors. 

If the RC bit is set to one and errors occur in reading or transfer of the data, the device shall continue 
to transfer the amount of data requested and then provide ending status with the BSY bit cleared to 
zero, the SE bit set to one, the ERR bit cleared to zero, and the type of error, UNC, IDNF, or ABRT, 
reported in the error log. 

If the RC bit is set to one and the Command Completion Time Limit expires, the device shall stop 
execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit set 
to one, the ERR bit cleared to zero, and report the fact that the Command Completion Time Limit 
expired by setting the CCTO bit in the error log to one. 

In all cases, the device shall attempt to transfer the amount of data requested within the Comand 
Completion Time Limit even if some data transferred is in error. 

NS (Not Sequential) may be set to one if the next read stream command with the same Stream ID may 
not be sequential in LBA space. Any read of the device media or internal device buffer management 
as a result of the state of the NS bit is device vendor specific. 

HSE (Handle Streaming Error) specifies that this command starts at the LBA of the last reported error for 
this stream, so the device may attempt to continue its corresponding error recovery sequence where 
it left off earlier. 

r ibdicates reserved. 
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Stream ID specifies the stream being read. The device shall operate according to the Stream ID set by 
the READ STREAM command. Any read of the device media or internal device buffer management 
as a result of the Stream ID is device vendor specific. 

Features register previous - 
The additional time allowed for the current commanda’s completion is calculated as follows: 
Command Completion Time Limit = (content of the Features register Previous) 
* (IDENTIFY DEVICE data words (99:98)) microseconds 
If the value is zero, the device shall use the Default Command Completion Time Limit supplied with a 
previous CONFIGURE STREAM command for this Stream ID. If the Default Command Completion 
Time Limit is zero, or no previous Configure Stream command was defined for this Stream ID, the 
result is vendor specific. The time is measured from the write of the command register to command 
completion. 
Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 


6.39.5 Normal Outputs 


fRegister CCU CT UT CTC LCT U4 CUT UT 2 
Sector Count | HOB =0 Reserved 
HOB=1 Reserved 
LBA Low Reserved 


Reserved 
LBA Mid = Reserved 


Reserved 


LBA High Reserved 
Reserved 


Status DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Reserved 


Device/Head register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SE (Stream Error) shall be cleared to zero. 
DRQ shall be cleared to zero. 
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ERR shall be cleared to zero. 


6.39.6 Error Outputs 


If the RC bit is cleared to zero, the content of the registers shal be as shown below. If the RC bit is set to 
one, the SE bit shall be set to one, the ERR bit shall be cleared to zero, and the content of the Error register 
shown below shall be placed in the error log. 


| Register | 7] | ST a a 


HOB =1 Length of Stream Error (15:8 
HOB=1 LBA (31:24 
LBA Mid LBA (15:8) 


LBA (39:32) 
LBA High LBA (23:16) 


Reserved 
| Status | BSY | DRDY [| SE | DWE | DRQ | na _[ na _| 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the last 
command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if an 
address outside of the range of user-accessible addresses is requested if command aborted is not 
returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able to 
complete the action requested by the command. ABRT shall be set to one if an address outside of 
the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

CCTO (Command Completion Time Limit Out) bit shall be set to one if a Command Completion Time 
Limit Out error has occurred. 

Sector Count Current - 

bits (7:0) number of contiguous sectors containing potentially bad data, beginning with the LBA of the 

first sector with an uncorrectable error. 
Sector Count Previous - 

bits (15:8) of the number of contiguous sectors containing potentially bad data, starting at the address of 

the first uncorrectable error 
LBA Low Current - 

bits (7:0) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA Low Previous - 

bits (31:24) of the address of the first uncorrectable error when read with Device Control register HOB 

set to one. 
LBA Mid Current- 

bits (15:8) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA Mid Previous- 
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bits (39:32) of the address of the first uncorrectable error when read with Device Control register HOB 

set to one. 
LBA High Current - 

bits (23:16) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA High Current - 
bits (47:40) of the address of the first uncorrectable error when read with Device Control register HOB 
set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

SE (Stream Error) shall be set to one if an error has occurred during the execution of the command and 
the RC bit is set to one. In this case the LBA returned in the Sector Number registers shall be the 
address of the first sector in error, and the Sector Count registers shall contain the number of 
consecutive sectors that may contain errors. If the RC bit is set to one when the command is issued 
and a UNC, IDNF, ABRT, or CCTO error occurs, the SE bit shall be set to one, the ERR bit shall be 
cleared to zero, and the bits that would normally be set in the Error register shall be set in the error 
log. 

DWE (Deferred Write Error) shall be set to one if an error was detected in a deferred write to the media 
for a previous WRITE STREAM DMA EXT or WRITE STREAM EXT command. This error is from a 
previously issued command. If DWE is set to one, the location of the deferred error is only reported 
in the Write Stream error log. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one and RC is cleared to zero. If the RC bit is set 
to one when the command is issued and a UNC, IDNF, ABRT, or CCTO error occurs, the SE bit 
shall be set to one, the ERR bit shall be cleared to zero, and the bits that would normally be set in 
the Error register shall be set in the error log. 


6.39.7 Prerequisites 
DRDY set to one and BSY cleared to zero. 
6.39.8 Description 


The command reads from 1 to 65536 sectors as specified in the Sector Count register. A sector count of 
value 0000h requests 65,536 sectors. The transfer shall begin at the sector specified in the Sector Number 
register. 


The RC bit specifies that the drive operate in a continuous read mode for the READ STREAM command. 
When RC is cleared to zero the drive shall operate in normal Streaming read mode. 


When the Read Continuous mode is enabled, the device shall transfer data of the requested length without 
setting the error bit. The SE bit shall be set to one if the data transferred includes errors. The data may be 
erroneous in this case. If an error is encountered, it may be necessary for the device to pad the data being 
transferred in order to fulfill the host’s requested transfer size. The implementation of the padding is vendor 
specific. 


The DRQ bit is always set to one prior to data transfer regardless of the presence or absence of an error 
condition. 


If the Read Continuous bit is set to one,the device shall not stop execution of the command due to errors. If 
thr RC bit is set to one and errors occur in reading or transfer of the data, the device shall continue to 
transfer the amount of data requested and then provide ending status with the BSY bit cleared to zero, the 
SE bit set to one, the ERR bit cleared to zero, and the type of error, UNC, IDNF, or ABRT, reported in the 
error log. If the RC bit is set to one and the Command Completion Time Limit expires, the device shall stop 
execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit set to one, 
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the ERR bit cleared to zero, and report the fact that the Command Completion Time Limit expired by setting 
the CCTO bit in the error log to one. In all cases, the device shall attempt to transfer the amount of data 
requested within the Comand Completion Time Limit even if some data transferred is in error. 
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6.40 READ VERIFY SECTOR(S) 
6.40.1 Command code 

40h 

6.40.2 Feature set 

General feature set 


— Mandatory for all devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.40.3 Protocol 
Non-data (See Clause 11). 


6.40.4 Inputs 


| Register | 7] OT ST 5 a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.40.5 Normal outputs 


| Register | 7] | 6 OT a 


| Status | BSY_ | DRDY [| DF | ona | DRQ | na | ona {ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
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BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.40.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. 


| Register |] 7 | 6 UT S| a a 
P| Error =| Sma S| UNC [| MC _ | IDNF | MCR | ABRT | NM | obs | 
| Sector Count fg 


LBA (3:16) 
| Status | BSY | DRDY | DF | na_ | oRQ | na _[ _na_[ ERR | 


Error register - 

UNC shall be set to one if data is uncorrectable. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.40.7 Prerequisites 
DRDY set to one. 
6.40.8 Description 


This command is identical to the READ SECTOR(S) command, except that the device shall have read the 
data from the media, the DRQ bit is never set to one, and no data is transferred to the host. 
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6.41 READ VERIFY SECTOR(S) EXT 
6.41.1 Command code 

42h 

6.41.2 Feature set 


48-bit Address feature set 
— Mandatory for all devices implementing the 48-bit Address feature set. 
— Use prohibited when the PACKET command feature set is implemented 


6.41.3 Protocol 
Non-data (See Clause 11). 


6.41.4 Inputs 


[Register FST 7] TUT LC A 
Features Current Reserved 
Previous Reserved 
Sector Count | Current Sector count (7:0) 
Previous Sector count (15:8) 
LBA Low Current LBA (7:0) 
Previous LBA (31:24) 
LBA Mid Current LBA (15:8) 
Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.41.5 Normal outputs 


[Register S| Tl UT LU AT 2 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 
LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.41.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. 


| Register | 7] | 6 CT 5 | A | 8 Ta 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
UNC shall be set to one if data is uncorrectable. 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
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MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.41.7 Prerequisites 
DRDY set to one. 
6.41.8 Description 


This command is identical to the READ SECTOR(S) EXT command, except that the device shall have read 
the data from the media, the DRQ bit is never set to one, and no data is transferred to the host. 
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6.42 SECURITY DISABLE PASSWORD 
6.42.1 Command code 
F6h 
6.42.2 Feature set 
Security Mode feature set. 
— Mandatory when the Security Mode feature set is implemented. 
6.42.3 Protocol 
PIO data-out (See Clause 11). 


6.42.4 Inputs 


| Register | 7 OT 6 OT 5 a 
pos patie fa 
| SectorCount Pn 
Pp LBA Low Pn 


Pp LBAMig Pa 
ie ——— EB AiG = te a 
}_Device _{ obs _| na _| obs _| DEV [ina 


Device register - 
DEV shall specify the selected device. 


6.42.5 Normal outputs 


| Register | 7] | 6 TS a Tt 
a |” 
| SectorCount. Pn 
Pp LBALow Pa 


|} —_EBA Mid fg 
[Device [obs [na [obs [bev [ra 
Bsy_ [| DRDY | DF | na | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.42.6 Error outputs 


The device shall return command aborted if the command is not supported, the device is in Locked mode, or 
the device is in Frozen mode. 
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| Register | 7 | 6 CT TT a 
—— ee 


Beer eee 
satus [sy prov [br [na ORT ne | ne 


Error register - 
ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.42.7 Prerequisites 
DRDY set to one. Device shall be in Unlocked mode. 
6.42.8 Description 


The SECURITY DISABLE PASSWORD command transfers 512 bytes of data from the host. Table 37 
defines the content of this information. If the password selected by word 0 matches the password previously 
saved by the device, the device shall disable the Lock mode. This command shall not change the 
Masterpassword. The Master password shall be reactivated when a User password is set(See 4.7). 


Table 37 - Security password content 


| Word Content 


Control word 
Bit O Identifier O=compare User password 
1=compare Masterpassword 


Bit (15:1) Reserved 
Password (32 bytes) 
Reserved 
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6.43 SECURITY ERASE PREPARE 
6.43.1 Command code 
F3h 
6.43.2 Feature set 
Security Mode feature set. 
— Mandatory when the Security Mode feature set is implemented. 
6.43.3 Protocol 
Non-data (See Clause 11). 


6.43.4 Inputs 


| Register | 7 OT ST a 
pos epatures fa 
| SectorCount Pn 
Pp LBA Low Pn 


Pp LBAMig Pa 
EBA ig = tt ea 
}_Device __{ obs _| na _| obs _| DEV [ina 


Device register - 
DEV shall specify the selected device. 


6.43.5 Normal outputs 


| Register | 7] | 6 OT a Tt 
a a (a 
| SectorCount, Pn 
Pp LBALow Pa 


Pp LBAMig Pa 
BG a FE | 
| Device | obs | oma_{ obs | DEV | ma | ma | na | na_ | 
Bsy_[ DRDY | DF | na | DRQ {na | na _ | ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.43.6 Error outputs 


The device shall return command aborted if the command is not supported or the device is in Frozen mode. 
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| Register | 7 | 6 CT TT a 
—— ee 


pete! —— oe naa 
satus [sy prov [br | na OR ne | na 


Error register - 
ABRT shall be set to one if this command is not supported or device is in Frozen mode. ABRT may 
be set to one if the device is not able to complete the action requested by the command. 


NOTE - In a previous revision of this standard, there were conflicting descriptions of the handling of this 
command when in the Frozen mode. 


Device register - 
DEV shall indicate the selected device. 

Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.43.7 Prerequisites 

DRDY set to one. 

6.43.8 Description 

The SECURITY ERASE PREPARE command shall be issued immediately before the SECURITY ERASE 


UNIT command to enable device erasing and unlocking. This command prevents accidental loss of data on 
the device. 
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6.44 SECURITY ERASE UNIT 
6.44.1 Command code 
F4h 
6.44.2 Feature set 
Security Mode feature set. 
— Mandatory when the Security Mode feature set is implemented. 
6.44.3 Protocol 
PIO data-out (See Clause 11). 


6.44.4 Inputs 


| Register | 7] OT ST a Tt 


LBA Mid 


LBA High na 


Pe ee a 
obs 
a 


Command F4h 


Device register - 
DEV shall specify the selected device. 


6.44.5 Normal outputs 


| Register | 7] | 6 OT a Tt 


BSy_ [| DRDY | DF | na | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.44.6 Error outputs 
The device shall return command aborted if the command is not supported, the device is in Frozen mode, 


not preceded by a SECURITY ERASE PREPARE command, if Enhance Erase is specified but not 
supported, or if the data area is not successfully overwritten. 
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| Register | 7 | 6 CT TT a 
—— ee 


pete! —— oe nea 
satus ssy—[ bry [br [na Re Yn 


Error register - 

ABRT shall be set to one if this command is not supported, device is in Frozen mode, not preceded 
by a SECURITY ERASE PREPARE command, or if the data area is not successfully 
overwritten. ABRT may be set to one if the device is not able to complete the action 
requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.44.7 Prerequisites 


DRDY set to one. This command shall be immediately preceded by a SECURITY ERASE PREPARE 
command. 


6.44.8 Description 


This command transfers 512 bytes of data from the host. Table 38 defines the content of this information. If 
the password does not match the password previously saved by the device, the device shall reject the 
command with command aborted. 


The SECURITY ERASE PREPARE command shall be completed immediately prior to the SECURITY 
ERASE UNIT commana. If the device receives a SECURITY ERASE UNIT command without an immediately 
prior SECURITY ERASE PREPARE command, the device shall command abort the SECURITY ERASE 
UNIT command. 


When Normal Erase mode isspecified, the SECURITY ERASE UNIT command shall write binary zeroes to 
all user data areas. The Enhanced Erase mode is optional. When Enhanced Erase mode isspecified, the 
device shall write predetermined data patterns to all user data areas. In Enhanced Erase mode, all 
previously written user data shall be overwritten, including sectors that are no longer in use due to 
reallocation. 


This command shall disable the device Lock mode, however, the Masterpassword shall still be stored 
internally within the device and may be reactivated later when a new User password is set. 


Page 239 


T13/1532D Volume 1 Revision 4b 


Table 38 - SECURITY ERASE UNIT password 


| Word | Content 


Control word 

Bit O Identifier 0=Compare User password 
1=Compare Master password 

Bit 1 Erase mode 0=Normal Erase 
1=Enhanced Erase 


Bit (15:2) | Reserved 


Password (32 bytes) 
17-255 
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6.45 SECURITY FREEZE LOCK 
6.45.1 Command code 
F5h 
6.45.2 Feature set 
Security Mode feature set. 
— Mandatory when the Security Mode feature set is implemented. 
6.45.3 Protocol 
Non-data (See Clause 11). 


6.45.4 Inputs 


| Register | 7] OT ST a 
features. ig 
| SectorCount, Pn 
Pp LBA Low Pn 


Pp LBAMig Pa 
pe — LES a a 
Device __{ obs _| na _| obs _| DEV [ina 


Device register - 
DEV shall specify the selected device. 


6.45.5 Normal outputs 


| Register | 7] | 6 OT 5 A a Tt 
fe EOF —— Sf 
| SectorCount_ Pn 
Pp LBALow Pa 


|} _EBA Mid fg 
[device [obs [na [obs [ber 
| Status | BSY | DRDY [| DF | na | ORQ | na | na _[ ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.45.6 Error outputs 


The device shall return command aborted if the command is not supported, or the device is in Locked mode. 
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| Register | 7 | 6 CT Tt | 
Pp Error S| Cn S| na S| na S| n=] SaaS] ABRT | na | a_i 
| ss SectorCount, Pn 
Pp LBALow Pa 


Po LBAMig Pm 
ame SED OORIONS = Aste Te a Ge ee ee eee 
| Status | BSY [| DRDY | DF | na_| DRQ | 
Error register - 

ABRT shall be set to one if this command is not supported or device is in locked mode. ABRT may 

be set to one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 


DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.45.7 Prerequisites 
DRDY set to one. 
6.45.8 Description 


The SECURITY FREEZE LOCK command shall set the device to Frozen mode. After command completion 
any other commands that update the device Lock mode shall be command aborted. Frozen mode shall be 
disabled by power-off or hardware reset. If SECURITY FREEZE LOCK shall be issued when the device is in 
Frozen mode, the command executes and the device shall remain in Frozen mode. 


Commands disabled by SECURITY FREEZE LOCK are: 


— SECURITY SET PASSWORD 

— SECURITY UNLOCK 

— SECURITY DISABLE PASSWORD 
— SECURITY ERASE PREPARE 

— SECURITY ERASE UNIT 
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6.46 SECURITY SET PASSWORD 
6.46.1 Command code 
Fih 
6.46.2 Feature set 
Security Mode feature set. 
— Mandatory when the Security Mode feature set is implemented. 
6.46.3 Protocol 
PIO data-out (See Clause 11). 


6.46.4 Inputs 


| Register | 7] OT 6 OT a 
features. ig 
| SectorCount, Pn 
Pp LBA Low Pn 


p LBAMig Pa 
fe — LES a 
Device __{ obs _| na _| obs _| DEV [ina 


Device register - 
DEV shall specify the selected device. 


6.46.5 Normal outputs 


| Register | 7] | 6 CT a Tt 
a a 
| —— SectorCount Pm 
Pp LBALow Pa 


| _EBA Mid fg 
[device [obs [na [obs [per 
| Status | BSY | DRDY [| DF | na _ | ORQ | na | na _{ ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.46.6 Error outputs 


The device shall return command aborted if the command is not supported, the device is in Locked mode, or 
the device is in Frozen mode. 
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| Register | 7] | | TT a 


na 
| Status | SY | DRDY [| DF | na | ORQ | na | na { ERR | 


Error register - 

ABRT shall be set to one if this command is not supported, if device is in Frozen mode, or if device is 
in locked mode. ABRT may be set to one if the device is not able to complete the action 
requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.46.7 Prerequisites 

DRDY set to one. 

6.46.8 Description 

This command transfers 512 bytes of data from the host. Table 39 defines the content of this information. 
The data transferred controls the function of this command. Table 40 defines the interaction of the identifier 
and security level bits. 

The revision code field shall be returned in the IDENTIFY DEVICE data word 92. The valid revision codes 


are 0001h through FFFEh. A value of 0000h or FFFFh indicates that the Master Password Revision Code is 
not supported. 


Table 39 - SECURITY SET PASSWORD data content 


| Word _| 

Control word 

Bit O Identifier O=set User password 
1=set Master password 

Bits (7:1) Reserved 

Bit 8 Security level O=High 
1=Maximum 

Bits (15:9) | Reserved 


Password (32 bytes) 
Master Password Revision Code (valid if word 0 bit 0 = 1) 
18-255 
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Table 40 - Identifier and security level bit interaction 


[Identifier | Level__| Command result 


User High The password supplied with the command shall be saved as the new User password. 
The Lock mode shall be enabled from the next power-on or hardware reset. The 
device shall then be unlocked by either the User password or the previously set 
Master password. 


User Maximum | The password supplied with the command shall be saved as the new User password. 
The Lock mode shall be enabled from the next power-on or hardware reset. The 
device shall then be unlocked by only the User password. The Master password 
previously set is still stored in the device but shall not be used to unlock the device. 


Master High or This combination shall set a Master password but shall not enable or disable the Lock 
Maximum | mode. The security level is not changed. Master password revision code set to the 
value in Master Password Revision Code field. 
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6.47 SECURITY UNLOCK 
6.47.1 Command code 
F2h 
6.47.2 Feature set 
Security Mode feature set. 
— Mandatory when the Security Mode feature set is implemented. 
6.47.3 Protocol 
PIO data-out (See Clause 11). 


6.47.4 Inputs 


| Register | 7] OT 6 OT a Tt 
Po = epatures fa 
| SectorCount Pn 
Pp LBA Low Pn 


Pp LBAMig Pa 
fe ——— EB Aig = te a 
}_Device__{ obs _| na _| obs _| DEV [ina 


Device register - 
DEV shall specify the selected device. 


6.47.5 Normal outputs 


| Register | 7] | 6 OT a fT 
a |” 
| SectorCount, Pn 
Pp LBALow Pa 


| —_EBA Mid fg 
[device [obs [na [obs [per 
Bsy_[ DRDY | DF | na | bRQ {na {| na _ | ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.47.6 Error outputs 


The device shall return command aborted if the command is not supported, or the device is in Frozen mode. 
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| Register | 7 | 6 CT TT a 
—— ee 


Pepe eee eee 
satus [sy bry [br [na ORT na | ne 


Error register - 

ABRT shall be set to one if this command is not supported or if device is in Frozen mode. ABRT may 

be set to one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.47.7 Prerequisites 

DRDY set to one. 

6.47.8 Description 

This command transfers 512 bytes of data from the host. Table 37 defines the content of this information. 


If the Identifier bit is set to Master and the device is in high security level, then the password supplied shall 
be compared with the stored Master password. If the device is in maximum security level then the unlock 
shall be rejected. 


If the Identifier bit is set to user then the device shall compare the supplied password with the stored User 
password. 


If the password compare fails then the device shall return command aborted to the host and decrements the 
unlock counter. This counter shall be initially set to five and shall be decremented for each password 
mismatch when SECURITY UNLOCK is issued and the device is locked. When this counter reaches zero 
then SECURITY UNLOCK and SECURITY ERASE UNIT commands shall be command aborted until a 
power-on reset or a hardware reset. SECURITY UNLOCK commands issued when the device is unlocked 
have no effect on the unlock counter. 


Page 247 


T13/1532D Volume 1 Revision 4b 


6.48 SERVICE 

6.48.1 Command code 

A2h 

6.48.2 Feature set 

Overlap and Queued feature sets 

Mandatory when the Overlapped feature set is implemented. 
6.48.3 Protocol 

PACKET or READ/WRITE DMA QUEUED (See Clause 11). 


6.48.4 Inputs 


| Register | 7] OT ST a 


LBA Mid 


LBA High na 


Command A2h 


Device register - 
DEV shall specify the selected device. 


6.48.5 Outputs 


Outputs as a result of a SERVICE command are described in the command description for the command for 
which SERVICE is being requested. 


6.48.6 Prerequisites 

The device shall have performed a bus release for a previous overlap PACKET, READ DMA QUEUED, 
READ DMA QUEUED EXT, WRITE DMA QUEUED, or WRITE DMA QUEUED EXT command and shall 
have set the SERV bit to one to request the SERVICE command be issued to continue data transfer and/or 
provide command status (See 6.49.21). 


6.48.7 Description 


The SERVICE command is used to provide data transfer and/or status of a command that was previously 
bus released. 
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6.49 SET FEATURES 
6.49.1 Command code 
EFh 
6.49.2 Feature set 
General feature set 
— Mandatory for all devices. 
— Set transfer mode subcommand is mandatory. 
— Enable/disable write cache subcommands are mandatory when a write cache is implemented. 
— Enable/disable Media Status Notification sub commands are mandatory if the Removable Media 
feature set is implemented. 
— All other subcommands are optional. 
6.49.3 Protocol 
Non-data (See Clause 11). 
6.49.4 Inputs 


Table 41 defines the value of the subcommand in the Feature register. Some subcommands use other 
registers, such as the Sector Count register to pass additional information to the device. 


| CC Register | 7] OT 6 | CUT A 2 a 
Subcommand code 


LBA Mid Subcommand specific 
LBA High Subcommand specific 
| Device | obs | na |_obs, |] DEV | ona [ ma | na | na | 


Device register - 
DEV shall specify the selected device. 


6.49.5 Normal outputs 
See the subcommand descriptions. 
6.49.6 Error outputs 


If any subcommand input value is not supported or is invalid, the device shall return command aborted. 


| Register | 7 | 6 OT CT 4 2 
——— 


a Se SC el 
[satus [sy prov [br [na Ra | ne ER 
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Error register - 

ABRT shall be set to one if this subcommand is not supported or if the value is invalid. ABRT may be 

set to one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.49.7 Prerequisites 
DRDY shall be set to one. 
6.49.8 Description 


This command is used by the host to establish parameters that affect the execution of certain device 
features. Table 41 defines these features. 


At power-on, or after a hardware reset, the default settings of the functions specified by the subcommands 
are vendor specific. 
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Table 41 - SET FEATURES register definitions 


Value 
fmm | 
04h 
OAh 
43h 
Disable reverting to power-on defaults 


Disable release interrupt 
Disable SERVICE interrupt 


FOh-FFh Reserved for assignment by the CompactFlash™ Association 
NOTE -— All values not shown are reserved for future definition. 


6.49.9 Enable/disable 8-bit PIO data transfer 
Devices implementing the CFA feature set shall support 8-bit PIO data transfers. Devices not implementing 


the CFA feature set shall not support 8-bit PIO data transfers. When 8-bit PIO data transfer is enabled the 
Data register is 8-bits wide using only DD7 to DDO. 
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6.49.10 Enable/disable write cache 


Subcommand codes 02h and 82h allow the host to enable or disable write cache in devices that implement 
write cache. When the subcommand disable write cache is issued, the device shall initiate the sequence to 
flush cache to non-volatile memory before command completion (See 6.14). This subcommand does not 
apply to commands that have a Flush to Disk bit. 


6.49.11 Set transfer mode 
A host selects the transfer mechanism by Set Transfer Mode, subcommand code 03h, and specifying a 


value in the Sector Count register. The upper 5 bits define the type of transfer and the low order 3 bits 
encode the mode value. The host may change the selected modes by the SET FEATURES command. 


Table 42 - Transfer mode values 
Pp Mode CS Bits (7:3) _| Bits (2:0) | 


Multiword DMA mode 00100b mode 
Ultra DMA mode 01000b 
10000b 


mode = transfer mode number 


If a device supports this standard, and receives a SET FEATURES command with a Set Transfer Mode 
parameter and a Sector Count register value of “OOOOOO000b”, the device shall set the default PlO mode. If 
the value is “O0000001b” and the device supports disabling of IORDY, then the device shall set the default 
PIO mode and disable IORDY. A device shall support all PIO modes below the highest mode supported, 
e.g., if PIO mode 1 is supported PIO mode 0 shall be supported. 


Support of IORDY is mandatory when PIO mode 3 or above is the current mode of operation. 


A device shall support all Multiword DMA modes below the highest mode supported, e.g., if Multiword DMA 
mode 1 is supported Multiword DMA mode 0 shall be supported. 


A device shall support all Ultra DMA modes below the highest mode supported, e.g., if Ultra DMA mode 1 is 
supported Ultra DMA mode 0 shall be supported. 


If an Ultra DMA mode is enabled any previously enabled Multiword DMA mode shall be disabled by the 
device. If a Multiword DMA mode is enabled any previously enabled Ultra DMA mode shall be disabled by 
the device. 


For systems using a cable assembly, the host shall detect that an 80-conductor cable assembly is 
connecting the host with the device(s) before enabling any Ultra DMA mode greater than 2 in the device(s) 
(See Volume 2, Annex A). 


6.49.12 Enable/disable advanced power management 


Subcommand code O5h allows the host to enable Advanced Power Management. To enable Advanced 
Power Management, the host writes the Sector Count register with the desired advanced power 
management level and then executes a SET FEATURES command with subcommand code 05h. The power 
management level is a scale from the lowest power consumption setting of 01h to the maximum performance 
level of FEh. Table 43 shows these values. 
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Table 43 - Advanced power management levels 


Device performance may increase with increasing power management levels. Device power consumption 
may increase with increasing power management levels. The power management levels may contain 
discrete bands. For example, a device may implement one power management method from 80h to AOh and 
a higher performance, higher power consumption method from level Aih to FEh. Advanced power 
management levels 80h and higher do not permit the device to spin down to save power. 


Subcommand code 85h disables Advanced Power Management. Subcommand 85h may not be 
implemented on all devices that implement SET FEATURES subcommand O5h. 


6.49.13 Enable/disable Power-Up In Standby feature set 


Subcommand code O6h enables the Power-Up In Standby feature set. When this feature set is enabled, the 
device shall power-up into Standby mode, i.e., the device shall be ready to receive commands but shall not 
spinup (See 4.12). Having been enabled, this feature shall remain enabled through power-down, hardware 
reset and software rest. 


Subcommand code 86h disables the Power-Up In Standby feature set. When this feature set is disabled, the 
device shall power-up into Active mode. The factory default for this feature set shall be disabled. 


6.49.14 Enable/disable CFA power mode 1 


Subcommand code OAh enables CFA Power Mode 1. CFA devices may consume up to 500 mA maximum 
average RMS current for either 3.3 V or 5 V operation in Power Mode 1. CFA devices revert to Power Mode 
1 on hardware or power-on reset. CFA devices revert to Power Mode 1 on software reset except when Set 
Features disable reverting to power-on defaults is set (See 6.17.67). Enabling CFA Power Mode 1 does not 
spin up rotating media devices. 


Subcommand 8Ah disables CFA Power Mode 1, placing the device to CFA Power Mode 0. CFA devices 
may consume up to 75 mA maximum average RMS current for 3.3 V or 100 mA maximum average RMS 
current for 5 V operation in Power Mode 0. 


A device in Power Mode 0 the device shall accept the following commands: 


— IDENTIFY DEVICE 

— SET FEATURES (function codes OAh and 8Ah) 
— STANDBY 

— STANDBY IMMEDIATE 

— SLEEP 

— CHECK POWER MODE 

— EXECUTE DEVICE DIAGNOSTICS 

— CFA REQUEST EXTENDED ERROR 


A device in Power Mode 0 may accept any command that the device is capable of executing within the 


Power Mode 0 current restrictions. Commands that require more current than specified for Power Mode 0 
shall be rejected with an abort error. 
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6.49.15 Power-Up In Standby feature set device spin-up 


Subcommand code 07h shall cause a device that has powered-up into Standby to go to the Active state (See 
4.12 and Figure 4). 


6.49.16 Enable/disable Media Status Notification 


Subcommand code 31h disables Media Status Notification and leaves the media in an unlocked state. If 
Media Status Notification is disabled when this subcommand is received, the subcommand has no effect. 


Subcommand code 95h enables Media Status Notification and clears any previous media lock state. This 
subcommand returns the device capabilities for media eject, media lock, previous state of Media Status 
Notification and the current version of Media Status Notification supported in the LBA Mid and LBA High 
registers as described below. 


| Register | 7] | 6 OT a Tt 
He a ER ee | 


LBA Mid VER 
LBA High LOCK | PENA 


LBA Mid register - 
VER shall contain the Media Status Notification version supported by the device (currently OxOOh). 
LBA High register - 
PENA shall be set to one if Media Status Notification was enabled prior to the receipt of this 
command. 
LOCK shall be set to one if the device is capable of locking the media preventing manual ejection. 
PEJ shall be set to one if the device has a power eject mechanism that is capable of physically 
ejecting the media when a MEDIA EJECT command is sent to the device. This bit shall be set to 
zero if the device only unlocks the media when the device receives a MEDIA EJECT command. 


6.49.17 Enable/disable Automatic Acoustic Management 


Subcommand code 42h allows the host to enable the Automatic Acoustic Management feature set. To 
enable the Automatic Acoustic Management feature set, the host writes the Sector Count register with the 
requested automatic acoustic management level and executes a SET FEATURES command with 
subcommand code 42h. The acoustic management level is selected on a scale from 01h to FEh. Table 44 
shows the acoustic management level values. 


Enabling or disabling of the Automatic Acoustic Management feature set, and the current automatic acoustic 
management level setting shall be preserved by the device across all forms of reset, i.e. power-on, 
hardware, and software resets. 


Table 44 - Automatic acoustic management levels 


FEh 
81h-FDh 


80h 
O1h-7Fh 
Vendor Specific 


Device performance may increase with increasing acoustic management levels. Device power consumption 
may decrease with decreasing acoustic management levels. The acoustic management levels may contain 
discrete bands. For example, a device may implement one acoustic management method from 80h to BFh 
and a higher performance, higher acoustic management method from level COh to FEh. 
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Upon successful completion of this SET FEATURES subcommand, IDENTIFY DEVICE or IDENTIFY 
PACKET DEVICE data word 94, bits (7:0) shall be updated by the device. If the command is aborted by the 
device, the previous automatic acoustic management state shall be retained. 


Subcommand code C2h disables the Automatic Acoustic Management feature set. Devices that implement 
SET FEATURES subcommand 42h are not required to implement subcommand C2h. If device successfully 
completes execution of this subcommand, then the acoustic behavior of the device shall be vendor-specific, 
and the device shall return zeros in bits (7:0) of word 94 and bit 9 of word 86 of the IDENTIFY DEVICE or 
IDENTIFY PACKET DEVICE data words. 


Upon completion of SET FEATURES subcommands 42h and C2h, the device may update words (97:96) and 
word 104 in IDENTIFY DEVICE or IDENTIFY PACKET DEVICE data words, and the contents of the Stream 
Performance Parameters Log in the READ LOG EXT command. 


6.49.18 Set Maximum Host Interface Sector Times 


Subcommand code 43h allows the host to inform the device of a host interface rate limitation. This 
information shall be used by the device to meet the Command Completion Time Limits of the commands of 
the streaming feature set. To inform the device of a host interface rate limitation, the host writes the LSB and 
MSB value of its Typical PIO Host Interface Sector Time to the Sector Count and LBA Low registers and 
writes the LSB and MSB value of its Typical DMA Host Interface Sector Time to the LBA Mid and LBA High 
registers. The Typical Host Interface Sector Times have the same units as IDENTITY DEVICE data word 96 
for DMA and word 104 for PIO. A value of zero indicates that the host interface shall be capable of 
transferring data at the maximum rate allowed by the selected transfer mode. The Typical PIO Mode Host 
Interface Sector Time includes the host's interrupt service time. 


Upon completion of SET FEATURES subcommand 43h, the device may adjust IDENTIFY DEVICE data 
words (97:96), and the contents of the Stream Performance Parameters Log in the READ LOG EXT 
command to allow for the specified host interface sector time. 


| ReGiste ts —— =) 7 Be Sf Bh | es = 1 
Typical PIO Mode Host Interface Sector Time (7:0) 


LBA Low Typical PIO Mode Host Interface Sector Time (15:8) 
LBA Mid Typical DMA Mode Host Interface Sector Time (7:0) 
LBA High Typical DMA Mode Host Interface Sector Time (15:8) 


6.49.19 Enable/disable read look-ahead 


Subcommand codes AAh and 55h allow the host to request the device to enable or disable read look-ahead. 
Error recovery performed by the device is vendor specific. 


6.49.20 Enable/disable release interrupt 


Subcommand codes 5Dh and DDh allow a host to enable or disable the asserting of Interrupt Pending when 
a device releases the bus for an overlapped PACKET command. 


6.49.21 Enable/disable SERVICE interrupt 


Subcommand codes 5Eh and DEh allow a host to enable or disable the asserting of an Interrupt Pending 
when DRQ is set to one in response to a SERVICE command. 


6.49.22 Enable/disable reverting to defaults 
Subcommand codes CCh and 66h allow the host to enable or disable the device from reverting to power-on 


default values. A setting of 66h allows settings that may have been modified since power-on to remain at the 
same setting after a software reset. 
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6.50 SET MAX 


Individual SET MAX commands are identified by the value placed in the Features register. Table 45 shows 
these Features register values. 


Table 45 - SET MAX Features register values 


SET MAX SET PASSWORD 


6.50.1 SET MAX ADDRESS 
6.50.1.1 Command code 

F9h (See 6.50.1.7). 

6.50.1.2 Feature set 

Host Protected Area feature set. 


— Mandatory when the Host Protected Area feature set is implemented. 
— Use prohibited when the Removable feature set is implemented. 


6.50.1.3 Protocol 
Non-data (See Clause 11). 


6.50.1.4 Inputs 


| Register | 7] OT 6 OT a tt 


SET MAX LBA (15:8) 

SET MAX LBA (23:16) 
SET MAX LBA (27:24) 
(| 


F9h 


Sector Count - 
VV (Value volatile). If bit 0 is set to one, the device shall preserve the maximum values over 
power-up or hardware reset. If bit 0 is cleared to zero, the device shall revert to the most recent non- 
volatile maximum address value setting over power-up or hardware reset. 
LBA Low - 
contains LBA bits (7:0) value to be set. 
LBA Mid - 
contains LBA bits (15:8) value to be set. 
LBA High - 
contains the LBA bits (23:16) value to be set. 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
Bits (3:0) contain the LBA bits (27:24) value to be set. 
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6.50.1.5 Normal outputs 


| Register | 7] | 6 OT a a 


| Status | BSY | DRDY [| DF | na _ | ORQ | na | na _{ ERR | 


LBA Low- 
LBA bits (7:0) set on the device. 
LBA Mid - 
LBA bits (15:8) set on the device. 
LBA High - 
LBA bits (23:16) set on device. 
Device - 
DEV shall indicate the selected device. 
LBA bits (27:24) set on the device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.50.1.6 Error outputs 
If this command is not supported, the maximum value to be set exceeds the capacity of the device, a host 


protected area has been established by a SET MAX ADDRESS EXT command, or the device is in the 
Set_Max_Locked or Set_Max_Frozen state, then the device shall return command aborted. 


| Register | 7] | ST a 


na 


Error register - 

ABRT shall be set to one if this command is not supported, maximum value requested exceeds the 
device capacity, a host protected area has been estabished by a SET MAX ADDRESS EXT 
command, the device is in the Set_Max_Locked or Set_Max_Frozen state, or the command 
is not immediately preceded by a READ NATIVE MAX ADDRESS command. ABRT may be 
set to one if the device is not able to complete the action requested by the command. 

IDNF shall be set to one if the command was the second non-volatile SET MAX ADDRESS 
command after power-on or hardware reset. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

ERR shall be set to one if an Error register bit is set to one. 
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6.50.1.7 Prerequisites 


DRDY set to one. A successful READ NATIVE MAX ADDRESS command shall immediately precede a SET 
MAX ADDRESS command. 


6.50.1.8 Description 
After successful command completion, all read and write access attempts to addresses greater than 
specified by the successful SET MAX ADDRESS command shall be rejected with an IDNF error. IDENTIFY 


DEVICE data words (61:60) shall reflect the maximum address set with this command. 


If the 48-bit Address feature set is supported, the value placed in IDENTIFY DEVICE data words (103:100) 
shall be the same as the value placed in words (61:60). 


Hosts shall not issue more than one non-volatile SET MAX ADDRESS or SET MAX ADDRESS EXT 
command after a power-on or hardware reset. Devices should report an IDNF error upon receiving a second 
non-volatile SET MAX ADDRESS command after a power-on or hardware reset. 


The contents of IDENTIFY DEVICE data words and the max address shall not be changed if a SET MAX 
ADDRESS command fails. 


After a successful SET MAX ADDRESS command using a new maximum LBA the content of all IDENTIFY 
DEVICE data words shall comply with 4.2.1 and the content of words (61:60) shall be equal to the new 
Maximum LBA + 1. 

6.50.2 SET MAX SET PASSWORD 

6.50.2.1 Command code 

F9h with the content of the Features register equal to 01h. 

6.50.2.2 Feature set 


Host Protected Area feature set. 


— Mandatory when the Host Protected Area feature set security extensions are implemented. 
— Use prohibited when the Removable feature set is implemented. 


6.50.2.3 Protocol 
PIO data-out (See Clause 11). 


6.50.2.4 Inputs 


| Register | 7] 6 OT a fT 
ee aN Se 
| SectorCount Pn 


Pp LBAMig Pa 
P| LBAHigh Pa 
| Device | obs | sna obs | DEV | na 
ea 2 a 


Device - 
DEV shall specify the selected device. 
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6.50.2.5 Normal outputs 


| Register | 7] | GT a 
a 1” 
| SectorCount Pn 
Pp LBALow Pn 


Pp LBAMig Pa 
He = SEB ABiGi ee es 
pp Davies obs [na | sobs: ) DEV =| = a 
| Status | SY | DRDY [| DF | na | DRQ | na | na _[ ERR | 


Device - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.50.2.6 Error outputs 


| Register | 7] OT G6 | Sa a 
poo as enor na has ha ic ha | ta) SABRI I iia] ha | 
| SectorCount, fn 
Pp LBALow Pn 

—— ee 


er — ae er eee 
| Status | BSY [ DRDY [ na | ona | ona | ona | na_{ ERR | 


Error register - 

ABRT shall be set to one if this command is not supported or the device is in the Set_Max_Locked or 
Set_Max_Frozen state. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

ERR shall be set to one if an Error register bit is set to one. 


6.50.2.7 Prerequisites 

DRDY set to one. This command shall not be immediately preceded by a READ NATIVE MAX ADDRESS 
command. If this command is immediately preceded by a READ NATIVE MAX ADDRESS commana, it shall 
be interpreted as a SET MAX ADDRESS command. 

6.50.2.8 Description 

This command requests a transfer of a single sector of data from the host. Table 46 defines the content of 


this sector of information. The password is retained by the device until the next power cycle. When the 
device accepts this command the device is in Set_Max_Unlocked state. 
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Table 46 - SET MAX SET PASSWORD data content 


| Word [| Content 


| oO 
Password (32 bytes 
17-255 


6.50.3 SET MAX LOCK 


6.50.3.1 Command code 

F9h with the content of the Features register equal to 02h. 
6.50.3.2 Feature set 

Host Protected Area feature set. 


— Mandatory when the Host Protected Area feature set security extensions are implemented. 
— Use prohibited when the Removable feature set is implemented. 


6.50.3.3 Protocol 
Non-data (See Clause 11). 


6.50.3.4 Inputs 


| Register | 7] OT 6 OT a a tt 


na 
na 
F9h 


Device - 
DEV shall specify the selected device. 


6.50.3.5 Normal outputs 


| Register | 7] | 6 OT a 
na 


na 
Bsy_[ DRDY | DF | ona | oRQ {na | na_| ERR | 


Device - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.50.3.6 Error outputs 


| Register | 7] OT OT a 
| Error S| CaS] ona S| ma S| na —| sna] ABRT | na _[ na _| 
hb = Sep ton Comat se Sia 
Pp LBALow Pn 


Pp LBAMig Pa 
P| LBAHigh Pa 
pe Devies — = = obs |r ha: — |= ebs: | DEV |i — a = | 
| Status | BSY | DRDY [ na | ona | ona | ona | na_{ ERR | 


Error register - 

ABRT shall be set to one if this command is not supported or the device is not in the 
Set_Max_Locked state. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

ERR shall be set to one if an Error register bit is set to one. 


6.50.3.7 Prerequisites 

DRDY set to one. This command shall not be immediately preceded by a READ NATIVE MAX ADDRESS 
command. If this command is immediately preceded by a READ NATIVE MAX ADDRESS commana, it shall 
be interpreted as a SET MAX ADDRESS command. 

6.50.3.8 Description 

The SET MAX LOCK command sets the device into Set_Max_Locked state. After this command is 
completed any other SET MAX commands except SET MAX UNLOCK and SET MAX FREEZE LOCK shall 
be command aborted. The device shall remain in this state until a power cycle or command completion 
without error of a SET MAX UNLOCK or SET MAX FREEZE LOCK command. 

6.50.4 SET MAX UNLOCK 

6.50.4.1 Command code 

F9h with the content of the Features register equal to 03h. 

6.50.4.2 Feature set 


Host Protected Area feature set. 


— Mandatory when the Host Protected Area feature set security extensions are implemented. 
— Use prohibited when the Removable feature set is implemented. 


6.50.4.3 Protocol 


PIO data-out (See Clause 11). 
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6.50.4.4 Inputs 


| Register | 7] OT G6 a a 
| Features PB 
| SectorCount_ Pn 


Device - 
DEV shall specify the selected device. 


6.50.4.5 Normal outputs 


| Register | 7] | 6 OT a Tt 
=< ( ” 
| SectorCount Pn 
[2 BA wie Fa CN 
ence = — tober eee mote | DEM = rae 
Bsy_[ DRDY | DF | na | ORQ {na | na _ | ERR | 


Device - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.50.4.6 Error outputs 


| Register | 7] 6 OT a 
| Error S| Crna S|] na S| ma S| na =| Sma] BRT | na _ | na _ | 
| SectorCount, Pn 
Pp LBALow Pn 

———— 


—orer oe ee ee $<“ 
| Status | BSY | DRDY [| na | ona | ona [ona | na {ERR | 


Error register - 

ABRT shall be set to one if this command is not supported or the device is not in the 
Set_Max_Locked state. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

ERR shall be set to one if an Error register bit is set to one. 
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6.50.4.7 Prerequisites 

DRDY set to one. This command shall not be immediately preceded by a READ NATIVE MAX ADDRESS 
command. If this command is immediately preceded by a READ NATIVE MAX ADDRESS command, it shall 
be interpreted as a SET MAX ADDRESS command. 

6.50.4.8 Description 


This command requests a transfer of a single sector of data from the host. Table 46 defines the content of 
this sector of information. 


The password supplied in the sector of data transferred shall be compared with the stored SET MAX 
password. 


If the password compare fails, then the device shall return command aborted and decrement the unlock 
counter. On the acceptance of the SET MAX LOCK command, this counter is set to a value of five and shall 
be decremented for each password mismatch when SET MAX UNLOCK is issued and the device is locked. 
When this counter reaches zero, then the SET MAX UNLOCK command shall return command aborted until 
a power cycle. 


If the password compare matches, then the device shall make a transition to the Set_Max_Unlocked state 
and all SET MAX commands shall be accepted. 


6.50.5 SET MAX FREEZE LOCK 

6.50.5.1 Command code 

F9h with the content of the Features register equal to 04h. 
6.50.5.2 Feature set 

Host Protected Area feature set. 


— Mandatory when the Host Protected Area feature set security extensions are implemented. 
— Use prohibited when the Removable feature set is implemented. 


6.50.5.3 Protocol 
Non-data (See Clause 11). 


6.50.5.4 Inputs 


| Register | 7] OT ST a 
a 
| SectorCount. Pn 


Pp LBAMiD Pa 
pe = UB AURIGH— —— 1) ee a = 
| Device | bs | sna sobs | DEV | 
po Command 


Device - 
DEV shall specify the selected device. 
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6.50.5.5 Normal outputs 


| Register | 7] | GT Sa a 
a a” 
| SectorCount Pn 
Pp LBALow Pn 


p LBA Mig Pa 
fr BA Bligh Sh =a 
| Device | obs | na | obs | DEV | na 
Bsy_| DRDY | DF | ona _ | DRQ [ na | na_| ERR | 


Device - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.50.5.6 Error outputs 


| Register | 7] 6 OT a 
| Error S| CaS] ona S| ma S| ma_—| Sma_— | BRT | na _ | na _ | 
| SectorCount, Pn 


a 1” 
| _EBA Mid fg 
[Device [obs [na [obs [per 
| Status | BSY [ DRDY [ na | ona | ona | ona | na_{ ERR | 


Error register - 

ABRT shall be set to one if this command is not supported or the device is in the Set_Max_Unlocked 
state. ABRT may be set to one if the device is not able to complete the action requested by 
the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

ERR shall be set to one if an Error register bit is set to one. 


6.50.5.7 Prerequisites 

DRDY set to one. A SET MAX SET PASSWORD command shall previously have been successfully 
completed. This command shall not be immediately preceded by a READ NATIVE MAX ADDRESS 
command. If this command is immediately preceded by a READ NATIVE MAX ADDRESS commana, it shall 
be interpreted as a SET MAX ADDRESS command. 

6.50.5.8 Description 


The SET MAX FREEZE LOCK command sets the device to Set_Max_Frozen state. After command 
completion any subsequent SET MAX commands shall be command aborted. 


Commands disabled by SET MAX FREEZE LOCK are: 
— SET MAX ADDRESS 
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— SET MAX SET PASSWORD 
— SET MAX LOCK 
— SET MAX UNLOCK 


Page 265 


T13/1532D Volume 1 Revision 4b 


6.51 SET MAX ADDRESS EXT 

6.51.1.1 Command code 

37h 

6.51.1.2 Feature set 

Host Protected Area feature set and 48-bit Address feature set. 


— Mandatory when the Host Protected Area feature set and the 48-bit Address feature set are 
implemented. 

— Use prohibited when the Removable Media feature set is implemented. 

— Use prohibited when PACKET Command feature set is implemented. 


6.51.1.3 Protocol 
Non-data (See Clause 11). 


6.51.1.4 Inputs 


pRegister CE CZ TS TK 
Features Current Reserved 
Previous Reserved 
Sector Count Current Reserved 
Previous Reserved 
LBA Low Current SET MAX LBA (7:0) 
Previous SET MAX LBA (31:24) 
LBA Mid Current SET MAX LBA (15:8) 
Previous SET MAX LBA (39:32) 
LBA High Current SET MAX LBA (23:16) 
Previous SET MAX LBA (47:40) 


NOTE —- The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 

V V (Value volatile). If bit O is set to one, the device shall preserve the maximum values over power- 
up or hardware reset. If bit O is cleared to zero, the device shall revert to the most recent 
non-volatile maximum address value setting over power-up or hardware reset. 

LBA Low Current - 
SET MAX LBA (7:0). 
LBA Low Previous - 
SET MAX LBA (31:24). 
LBA Mid Current - 
SET MAX LBA (15:8). 
LBA Mid Previous - 
SET MAX LBA (39:32). 
LBA High Current - 
SET MAX LBA (23:16). 
LBA High Previous - 
SET MAX LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.51.1.5 Normal outputs 


pRegister CT 
HOB=1 Reserved 
LBA Low SET MAX LBA (7:0) 
SET MAX LBA (31:24) 
LBA Mid SET MAX LBA (15:8) 
SET MAX LBA (39:32) 


LBA High SET MAX LBA (23:16) 
SET MAX LBA (47:40) 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


LBA Low - 
LBA (7:0) of the address of the SET MAX ADDRESS EXT when read with Device Control register 
HOB bit cleared to zero. 
LBA (31:24) of the address of the SET MAX ADDRESS EXT when read with Device Control register 
HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the SET MAX ADDRESS EXT when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the SET MAX ADDRESS EXT when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the SET MAX ADDRESS EXT when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the SET MAX ADDRESS EXT when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.51.1.6 Error outputs 
If this command is not supported, the maximum value to be set exceeds the capacity of the device, a host 
protected area has been established by a SET MAX ADDRESS command, the command is not immediately 


preceded by a READ NATIVE MAX ADDRESS EXT command, or the device is in the Set_Max_Locked or 
Set_Max_Frozen state, then the device shall return command aborted. 
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pRegister CU ZT UT 
Sector Count | HOB =0 Reserved 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

ABRT shall be set to one if this command is not supported, maximum value requested exceeds the 
device capacity, a host protected area has been established by a SET MAX ADDRESS 
command, or the command is not immediately preceded by a READ NATIVE MAX 
ADDRESS EXT command. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

IDNF shall be set to one if the command was the second non-volatile SET MAX ADDRESS or SET 
MAX ADDRESS EXT command after power-on or hardware reset. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.51.1.7 Prerequisites 


DRDY set to one. A successful READ NATIVE MAX ADDRESS EXT command shall immediately precede a 
SET MAX ADDRESS EXT command. 


6.51.1.8 Description 


After successful command completion, all read and write access attempts to addresses greater than 
specified by the successful SET MAX ADDRESS EXT command shall be rejected with an IDNF error. 


Hosts shall not issue more than one non-volatile SET MAX ADDRESS or SET MAX ADDRESS EXT 
command after a power-on or hardware reset. Devices shall report an IDNF error upon receiving a second 
non-volatile SET MAX ADDRESS EXT command after a power-on or hardware reset. 


The contents of IDENTIFY DEVICE data words and the max address shall not be changed if a SET MAX 
ADDRESS EXT command fails. 


After a successful SET MAX ADDRESS EXT command using a new maximum LBA the content of all 
IDENTIFY DEVICE data words shall comply with 6.2.1. 
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6.52 SET MULTIPLE MODE 
6.52.1 Command code 

Cé6h 

6.52.2 Feature set 

General feature set 


— Mandatory for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.52.3 Protocol 
Non-data (See Clause 11). 
6.52.4 Inputs 


If the content of the Sector Count register is not zero, then the Sector Count register contains the number of 
sectors per block for the device to be used on all following READ/WRITE MULTIPLE commands. The 
content of the Sector Count register shall be less than or equal to the value in bits (7:0) in word 47 in the 
IDENTIFY DEVICE data. The host should set the content of the Sector Count register to 1, 2, 4, 8, 16, 32, 
64 or 128. 


If the content of the Sector Count register is zero and the SET MULTIPLE command completes without error, 
then the device shall respond to any subsequent READ MULTIPLE or WRITE MULTIPLE command with 
command aborted until a subsequent successful SET MULTIPLE command completion where the Sector 
Count register is not set to Zero. 


| Register | 7] OT ST a 


Device register - 
DEV shall specify the selected device. 


6.52.5 Normal outputs 


| Register | 7] | 6 OT a Tt 


na 
| Status | BSY_ | DRDY [| DF | na _| ORQ | na | na _{ ERR | 
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Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.52.6 Error outputs 


If a block count is not supported, the device shall return command aborted. 


| Register | 7] | 6 | a 
re 


sce —— seared ae soba [eve = = es 
= siatus [sy bby [br [na Ra | eR 


Error register - 
ABRT shall be set to one if the block count is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.52.7 Prerequisites 
DRDY set to one. 
6.52.8 Description 


This command establishes the block count for READ MULTIPLE, READ MULTIPLE EXT, WRITE 
MULTIPLE, and WRITE MULTIPLE EXT commands. 


Devices shall support the block size specified in the IDENTIFY DEVICE parameter word 47, bits (7:0), and 
may also support smaller values. 


Upon receipt of the command, the device checks the Sector Count register. If the content of the Sector 
Count register is not zero, the Sector Count register contains a valid value, and the block count is supported, 
then the value in the Sector Count register is used for all subsequent READ MULTIPLE, READ MULTIPLE 
EXT, WRITE MULTIPLE, and WRITE MULTIPLE EXT commands and their execution is enabled. If the 
content of the Sector Count register is zero, the device may: 


1) disable multiple mode and respond with command aborted to all subsequent READ MULTIPLE, 
READ MULTIPLE EXT, WRITE MULTIPLE, and WRITE MULTIPLE EXT commands; 

2) respond with command aborted to the SET MULTIPLE MODE command; 

3) retain the previous multiple mode settings. 
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After a successful SET MULTIPLE command the device shall report the valid value set by that command in 
bits (7:0) in word 59 in the IDENTIFY DEVICE data. 


After a power-on or hardware reset, if bit 8 is set to one and bits (7:0) are cleared to zero in word 59 of the 
IDENTIFY DEVICE data, a SET MULTIPLE command is required before issuing a READ MULTIPLE, READ 
MULTIPLE EXT, WRITE MULTIPLE, or WRITE MULTIPLE EXT command. If bit 8 is set to one and bits (7:0) 
are not cleared to zero, a SET MULTIPLE command may be issue to change the multiple value required 
before issuing a READ MULTIPLE, READ MULTIPLE EXT, WRITE MULTIPLE, or WRITE MULTIPLE EXT 
command. 
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6.53 SLEEP 

6.53.1 Command code 

E6h 

6.53.2 Feature set 

Power Management feature set. 
— This command is mandatory for devices not implementing the PACKET Command feature set. 
— Power Management feature set is mandatory when power management is not implemented by 

the PACKET command set implemented by the device. 

— This command is mandatory when the Power Management feature set is implemented. 

6.53.3 Protocol 

Non-data (See Clause 11). 


6.53.4 Inputs 


| Register | 7 OT 6 OT TT a 
P= Reatites.— i). 2 a 
| SectorCount, Pn 
Pp LBALOw Pa 


BA Mid S| SF 
je BAGH, Pn 
| Device | obs | ona ~ obs | DEV | na Sd 
Pp Command 


Device register - 
DEV shall specify the selected device. 


6.53.5 Normal outputs 


| Register, | 7] | GT Sa a 
a a 1” 
| SectorCount, Pn 
p LBA Low Pa 


[-——" Bevis [obs na obs Br 
Bsy_[ DRDY | DF | na | ORQ {na | na | ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.53.6 Error outputs 


The device shall return command aborted if the device does not support the Power Management feature set. 


| Register | 7] | G6 | a a 
| Error S| Cn SO] na S| ma_—S| na —| Sma] ABRT | na | na _ | 
b= = Sebton Covi a SS ta 
ee EBA LOW: a) i= 


Pp LBAMig Pa 
f= BA High, 5 as 
p= = Davies sobs |. tha — | sobs: DEV =| a — 
| Status | SY | DRDY | DF | na | ORQ | na | na _{ ERR | 


Error register - 

ABRT shall be set to one if the device does not support the Power Management feature set. ABRT 
may be set to one if the device is not able to complete the action requested by the 
command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.53.7 Prerequisites 

DRDY set to one. 

6.53.8 Description 

This command is the only way to cause the device to enter Sleep mode. 

This command shall cause the device to set the BSY bit to one, prepare to enter Sleep mode, clear the BSY 
bit to zero and assert INTRQ. The host shall read the Status register in order to clear the Interrupt Pending 
and allow the device to enter Sleep mode. In Sleep mode, the device shall only respond to the assertion of 
the RESET- signal and the writing of the SRST bit in the Device Control register and shall release the device 
driven signal lines (See Figure 4). The host shall not attempt to access the Command Block registers while 


the device is in Sleep mode. 


Because some host systems may not read the Status register and clear the Interrupt Pending, a device may 
release INTRQ and enter Sleep mode after a vendor specific time period of not less than 2 s. 


The only way to recover from Sleep mode is with a software reset, a hardware reset, or a DEVICE RESET 
command. 


A device shall not power-on in Sleep mode nor remain in Sleep mode following a reset sequence. 
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6.54 SMART 


Individual SMART commands are identified by the value placed in the Feature register. Table 47 shows 
these Feature register values. 


Table 47 - SMART Feature register values 


vendor specific 


6.54.1 SMART DISABLE OPERATIONS 


6.54.1.1 Command code 

BOh with a Feature register value of D9h. 
6.54.1.2 Feature set 

SMART feature set. 


— Mandatory when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.1.3 Protocol 
Non-data (See Clause 11). 
6.54.1.4 Inputs 


The Features register shall be set to D9h. The LBA Mid register shall be set to 4Fh. The LBA High register 
shall be set to C2h. 


| Register | 7] OT ST a Tt 


2h 


Command BOh 


Device register - 
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DEV shall specify the selected device. 


6.54.1.5 Normal outputs 


| Register | 7] | 6 OT a a 


LBA Mid 


LBA High 
Status | psy | pRDY | DF | na | ORQ | na | na | ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.54.1.6 Error outputs 


If the device does not support this command, if SMART is not enabled, or if the values in the Features, LBA 
Mid, or LBA High registers are invalid, the device shall return command aborted. 


| Register | 7 | 6 | a 


na 
| Status | BSY | DRDY [| DF | na | ORQ | na | na _{ ERR | 


Error register - 

ABRT shall be set to one if this command is not supported, if SMART is not enabled, or if input 
register values are invalid. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.54.1.7 Prerequisites 
DRDY set to one. SMART enabled. 
6.54.1.8 Description 


This command disables all SMART capabilities within the device including any and all timer and event count 
functions related exclusively to this feature. After command acceptance the device shall disable all SMART 
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operations. SMART data shall no longer be monitored or saved by the device. The state of SMART, either 
enabled or disabled, shall be preserved by the device across power cycles. 

After receipt of this command by the device, all other SMART commands including SMART DISABLE 
OPERATIONS commands, with the exception of SMART ENABLE OPERATIONS, are disabled and invalid 
and shall be command aborted by the device. 

6.54.2 SMART ENABLEIDISABLE ATTRIBUTE AUTOSAVE 

6.54.2.1 Command code 

BOh with a Feature register value of D2h. 

6.54.2.2 Feature set 


SMART feature set. 


— Mandatory when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.2.3 Protocol 

Non-data (See Clause 11). 

6.54.2.4 Inputs 

The Features register shall be set to D2h. The LBA Mid register shall be set to 4Fh. The LBA High register 


shall be set to C2h. The Sector Count register shall set to 00h to disable attribute autosave and a value of 
Fih shall be set to enable attribute autosave. 


| Register | 7 OT 6 OT 5 4 a fT 


Device register - 
DEV shall specify the selected device. 


6.54.2.5 Normal outputs 


| Register | 7] | 6 OT a 


BSy_[ DRDY | DF | ona | ORQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
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DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.54.2.6 Error outputs 


If the device does not support this command, if SMART is disabled, or if the values in the Features, LBA Mid, 
or LBA High registers are invalid, the device shall return command aborted. 


| Register | 7] | 6 | a Tt 
p Error S| Cnt S| ma SO] mS] ona —S | SaaS] ABRT | na | na_| 
f= = specter Cunt | = ig Ee 
Pp LBALOW Pt 


_—_—_TBA Mid fg 
[device | obs_[_na [obs [Dev [ra 
/——siatus [sy bro [br [na ORT na | ne 


Error register - 

ABRT shall be set to one if this command is not supported, if SMART is disabled, or if the input 
register values are invalid. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.54.2.7 Prerequisites 
DRDY set to one. SMART enabled. 
6.54.2.8 Description 


This command enables and disables the optional attribute autosave feature of the device. This command 
may either allow the device, after some vendor specified event, to save the device updated attribute values 
to non-volatile memory; or this command may cause the autosave feature to be disabled. The state of the 
attribute autosave feature (either enabled or disabled) shall be preserved by the device across power cycles. 


A value of zero written by the host into the device’s Sector Count register before issuing this command shall 
cause this feature to be disabled. Disabling this feature does not preclude the device from saving SMART 
data to non-volatile memory during some other normal operation such as during a power-on or power-off 
sequence or during an error recovery sequence. 


A value of Fih written by the host into the device’s Sector Count register before issuing this command shall 
cause this feature to be enabled. Any other meaning of this value or any other non-zero value written by the 
host into this register before issuing this command may differ from device to device. The meaning of any 
non-zero value written to this register at this time shall be preserved by the device across power cycles. 


If this command is not supported by the device, the device shall return command aborted upon receipt from 
the host. 
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During execution of the autosave routine the device shall not set BSY to one nor clear DRDY to zero. If the 
device receives a command from the host while executing the autosave routine the device shall begin 
processing the command within two seconds. 

6.54.3 SMART ENABLE OPERATIONS 

6.54.3.1 Command code 

BOh with a Feature register value of D8h. 

6.54.3.2 Feature set 

SMART feature set. 


— Mandatory when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.3.3 Protocol 
Non-data (See Clause 11). 
6.54.3.4 Inputs 


The Features register shall be set to D8h. The LBA Mid register shall be set to 4Fh. The LBA High register 
shall be set to C2h. 


| Register | 7] OT 6 OT a Tt 
| Features PBA 
| SectorCount, Pn 


Device register - 
DEV shall specify the selected device. 


6.54.3.5 Normal outputs 


| Register | 7] 6 TS a a 
a a 1” 
| SectorCount, Pn 
Pp LBALow Pa 


Pp LBAMig Pa 
BG ee Se Se 2 a 
PY ——Deviees obs = fe na. 2] obs] DEW a = 
Bsy_ [| DRDY | DF | ona | oRQ {na | na_| ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.54.3.6 Error outputs 


If the device does not support this command or if the values in the Features, LBA Mid, or LBA High registers 
are invalid, the device shall return command aborted. 


| Register | 7] 6 | a a 
| Error S| CaS] na S| ma S| na —| Sna_— | ABRT | na | na _ | 
)  .Septon Court <a] ta 
PBA Low Pa 

——— ee ee 


a ee eT a 
=~ siatus [sy ory |r [na OR na | ne 


Error register - 
ABRT shall be set to one if this command is not supported or if the input register values are invalid. 
ABRT may be set to one if the device is not able to complete the action requested by the 
command. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.54.3.7 Prerequisites 

DRDY set to one. 

6.54.3.8 Description 

This command enables access to all SMART capabilities within the device. Prior to receipt of this command 
SMART data are neither monitored nor saved by the device. The state of SMART (either enabled or 
disabled) shall be preserved by the device across power cycles. Once enabled, the receipt of subsequent 
SMART ENABLE OPERATIONS commands shall not affect any SMART data or functions. 

6.54.4 SMART EXECUTE OFF-LINE IMMEDIATE 

6.54.4.1 Command code 

BOh with the content of the Features register equal to D4h 

6.54.4.2 Feature set 

SMART feature set. 


— Optional when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.4.3 Protocol 


Non-data (See Clause 11). 
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6.54.4.4 Inputs 


The Features register shall be set to D4h. The LBA Mid register shall be set to 4Fh. The LBA High register 
shall be set to C2h. Table 48 defines the subcommand that shall be executed based on the value in the LBA 
Low register. 


| Register | 7] OT 6 a a tt 
ee ene 


4Fh 
C2h 
na 
BOh 


Device register - 
DEV shall specify the selected device. 


6.54.4.5 Normal Outputs 


| Register | 7] OT 6 a a 
na 


a 1” 
na or C2h 
| Status | SY [ DRDY | DF | na_| ORQ | na | na _[ ERR | 


LBA Mid - 
na when the subcommand specified an off-line routine including an off-line self-test routine. 
4Fh when the subcommand specified a captive self-test routine (See 6.54.4.10) that has executed 
without failure. 
LBA High - 
na when the subcommand specified an off-line routine including an off-line self-test routine. 
C2h when the subcommand specified a captive self-test routine that has executed without failure. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.54.4.6 Error Outputs 
If the device does not support this command, if SMART is disabled, or if the values in the Features, LBA Mid, 
or LBA High registers are invalid, the device shall return command aborted. When a failure occurs while 


executing a test in captive mode, the device shall return command aborted with the LBA Mid register value of 
F4h and the LBA High value of 2Ch. 
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| Register | 7] 6 | a 


| Status | BSY [| DRDY | DF | na | ORQ | na | na _{ ERR | 


Error register - 

IDNF shall be set to one if SMART data sector’s ID field could not be found. 

ABRT shall be set to one if this command is not supported, if SMART is not enabled, if register 
values are invalid, or if a self-test fails while executing a sequence in captive mode. ABRT 
may be set to one if the device is not able to complete the action requested by the 
command. 

LBA Mid register - 

na when the subcommand specified an off-line routine (including an off-line self-test routine). 

AFh when the subcommand specified a captive self-test routine and some error other than a self-test 

routine failure occurred (i.e., if the sub-command is not supported or register values are invalid) 

F4h when the subcommand specified a captive self-test routine which has failed during execution. 

LBA High register - 

na when the subcommand specified an off-line routine (including an off-line self-test routine). 

2Ch when the subcommand specified a captive self-test routine which has failed during execution. 

C2h when the subcommand specified a captive self-test routine and some error other than a self-test 

routine failure occurred (i.e., if the sub-command is not supported or register values are invalid) 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one indicating that the device is capable of receiving any command. 

DF (Device Fault) shall be set to one indicating that a device fault has occurred. 

DRQ shall be cleared to zero indicating that there is no data to be transferred. 

ERR shall be set to one if any Error register bit is set to one. 


6.54.4.7 Prerequisites 

DRDY set to one. SMART enabled. 

6.54.4.8 Description 

This command causes the device to immediately initiate the optional set of activities that collect SMART data 


in an off-line mode and then save this data to the device's non-volatile memory, or execute a self-diagnostic 
test routine in either captive or off-line mode. 
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Table 48 - SMART EXECUTE OFF-LINE IMMEDIATE LBA Low register values 


| | Execute SMART off-line routine immediately in off-linemode 
Execute SMART Short self-test routine immediately in off-line mode 
Execute SMART Extended self-test routine immediately in off-line mode 


6.54.4.9 Off-line mode 


The following describes the protocol for executing a SMART EXECUTE OFF-LINE IMMEDIATE 
subcommand routine (including a self-test routine) in the off-line mode. 


a) The device shall execute command completion before executing the subcommand routine. 

b) After clearing BSY to zero and setting DRDY to one after receiving the command, the device shall not 
set BSY nor clear DRDY during execution of the subcommand routine. 

c) If the device is in the process of performing the subcommand routine and is interrupted by any new 
command from the host except a SLEEP, SMART DISABLE OPERATIONS, SMART EXECUTE OFF- 
LINE IMMEDIATE, or STANDBY IMMEDIATE command, the device shall suspend or abort the 
subcommand routine and service the host within two seconds after receipt of the new command. After 
servicing the interrupting command from the host the device may immediately re-initiate or resume the 
subcommand routine without any additional commands from the host (See 6.54.5.12). 

d) If the device is in the process of performing a subcommand routine and is interrupted by a SLEEP 
command from the host, the device may abort the subcommand routine and execute the SLEEP 
command. If the device is in the process of performing any self-test routine and is interrupted by a 
SLEEP command from the host, the device shall abort the subcommand routine and execute the SLEEP 
command. 

e) If the device is in the process of performing the subcommand routine and is interrupted by a SMART 
DISABLE OPERATIONS command from the host, the device shall suspend or abort the subcommand 
routine and service the host within two seconds after receipt of the command. Upon receipt of the next 
SMART ENABLE OPERATIONS command the device may, either re-initiate the subcommand routine or 
resume the subcommand routine from where it had been previously suspended. 

f) If the device is in the process of performing the subcommand routine and is interrupted by a SMART 
EXECUTE OFF-LINE IMMEDIATE command from the host, the device shall abort the subcommand 
routine and service the host within two seconds after receipt of the command. The device shall then 
service the new SMART EXECUTE OFF-LINE IMMEDIATE subcommand. 

g) If the device is in the process of performing the subcommand routine and is interrupted by a STANDBY 
IMMEDIATE or IDLE IMMEDIATE command from the host, the device shall suspend or abort the 
subcommand routine, and service the host within two seconds after receipt of the command. After 
receiving a new command that causes the device to exit a power saving mode, the device shall initiate or 
resume the subcommand routine without any additional commands from the host unless these activities 
were aborted by the host (See 6.54.5.8). 

h) While the device is performing the subcommand routine it shall not automatically change power states 
(e.g., aS a result of its Standby timer expiring). 

i) If a test failure occurs while a device is performing a self-test routine the device may discontinue the 
testing and place the test results in the Self-test execution status byte (See Table 49). 
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6.54.4.10 Captive mode 


When executing a self-test in captive mode, the device sets BSY to one and executes the self-test routine 
after receipt of the command. At the end of the routine the device places the results of this routine in the Self- 
test execution status byte (See Table 49) and executes command completion. If an error occurs while a 
device is performing the routine the device may discontinue its testing, place the results of this routine in the 
Self-test execution status byte, and complete the command. 


6.54.4.11 SMART off-line routine 


This routine shall only be performed in the off-line mode. The results of this routine are placed in the Off-line 
data collection status byte (See Table 50). 


6.54.4.12 SMART Short self-test routine 


Depending on the value in the LBA Low register, this self-test routine may be performed in either the captive 
or the off-line mode. This self-test routine should take on the order of ones of minutes to complete (See 
6.54.5.8). 


6.54.4.13 SMART Extended self-test routine 


Depending on the value in the LBA Low register, this self-test routine may be performed in either the captive 
or the off-line mode. This self-test routine should take on the order of tens of minutes to complete (See 
6.54.5.8). 


6.54.4.14 SMART Conveyance self-test routine 


Depending on the value in the LBA Low register, this self-test routine may be performed in either the captive 
or the off-line mode. This self-test routine is intended to identify damage incurred during transporting of the 
device. This self-test routine should take on the order of minutes to complete (See 6.54.5.8). 


6.54.4.15 SMART Selective self-test routine 


The SMART Selective self-test routine is an optional self-test routine. If the routine is implemented, all 
features of the routine shall be implemented. Support for the routine is indicated in off-line data collection 
capabilities (See 6.54.5.12). 


When the value in the LBA Low register is 4 or 132, the Selective self-test routine shall be performed. This 
self-test routine shall include the initial tests performed by the Extended self-test routine plus a selectable 
read scan. The host shall not write the Selective self-test log while the execution of a Selective self-test 
command is in progress. 


The user may choose to do read scan only on specific areas of the media. To do this, user shall set the test 
spans desired in the Selective self-test log and set the flags in the Feature flags field of the Selective self-test 
log to indicate do not perform off-line scan. In this case, the test spans defined shall be read scanned in their 
entirety. The Selective self-test log is updated as the self-test proceeds indicating test progress. When all 
specified test spans have been completed, the test is terminated and the appropriate self-test execution 
status is reported in the SMART READ DATA response depending on the occurrence of errors. Figure 9 
shows an example of a Selective self-test definition with three test spans defined. In this example, the test 
terminates when all three test spans have been scanned. 
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User LBA space 


Starting LBA for Starting LBA for Starting LBA for 
test span 1 test span 2 test span 3 


Ending LBA for Ending LBA for Ending LBA for 
test span 1 test span 2 test span 3 


Figure 9 - Selective self-test test span example 


After the scan of the selected spans described above, a user may wish to have the rest of media read 
scanned as an off-line scan. In this case, the user shall set the flag to enable off-line scan in addition to the 
other settings. If an error occurs during the scanning of the test spans, the error is reported in the self-test 
execution status in the SMART READ DATA response and the off-line scan is not executed. When the test 
spans defined have been scanned, the device shall then set the off-line scan pending and active flags in the 
Selective self-test log to one, the span under test to a value greater than five, the self-test execution status in 
the SMART READ DATA response to OOh, set a value of 03h in the off-line data collection status in the 
SMART READ DATA response and shall proceed to do an off-line read scan through all areas not included 
in the test spans. This off-line read scan shall completed as rapidly as possible, no pauses between block 
reads, and any errors encountered shall not be reported to the host. Instead error locations may be logged 
for future reallocation. If the device is powered-down before the off-line scan is completed, the off-line scan 
shall resume when the device is again powered up. From power-up, the resumption of the scan shall be 
delayed the time indicated in the Selective self-test pending time field in the Selective self-test log. During 
this delay time the pending flag shall be set to one and the active flag shall be set to zero in the Selective 
self-test log. Once the time expires, the active flag shall be set to one, and the off-line scan shall resume. 
When the entire media has been scanned, the off-line scan shall terminate, both the pending and active flags 
shall be cleared to zero, and the off-line data collection status in the SMART READ DATA response shall be 
set to 02h indicating completion. 


During execution of the Selective self-test, the self-test executions time byte in the Device SMART Data 
Structure may be updated but the accuracy may not be exact because of the nature of the test span 
segments. For this reason, the time to complete off-line testing and the self-test polling times are not valid. 
Progress through the test spans is indicated in the selective self-test log. 


A hardware or software reset shall abort the Selective self-test except when the pending bit is set to one in 
the Selective self-test log (See 6.54.6.8.5). The receipt of a SMART EXECUTE OFF-LINE IMMEDIATE 
command with OFh, Abort off-line test routine, in the LBA Low register shall abort Selective self-test 
regardless of where the device is in the execution of the command. If a second self-test is issued while a 
selective self-test is in progress, the selective self-test is aborted and the newly requested self-test is 
executed. 

6.54.5 SMART READ DATA 

6.54.5.1 Command code 


BOh with the content of the Features register equal to DOh. 
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6.54.5.2 Feature set 
SMART feature set. 
— Optional when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 
6.54.5.3 Protocol 
PIO data-in (See Clause 11). 
6.54.5.4 Inputs 


The Features register shall be set to DOh. The LBA Mid register shall be set to 4Fh. The LBA High register 
shall be set to C2h. 


| Register | 7] OT 6 a a 
| Features PO 
| SectorCount Pn 


| Device | obs | Sma] sobs | DEV | 
i Command, “sk SS SB eee 


Device register - 
DEV shall specify the selected device. 


6.54.5.5 Normal outputs 


| Register | 7 OT 6 | Sa a 
| Features Pa 
| SectorCount, Pn 
Pp LBALow Pn 


[device [obs [na] obs [bev [| 
| Status | SY [ DRDY | DF | na_ | ORQ | na | _na_{ ERR _| 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.54.5.6 Error outputs 


If the device does not support this command, if SMART is disabled, or if the values in the Features, LBA Mid, 
or LBA High registers are invalid, the device shall return command aborted. 
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| Register | 7 | 6 | UT a | 
——— re 


bees oe eee 
-—siatus [sy prov | br] na OR ne | na 


Error register - 

UNC shall be set to one if SMART data is uncorrectable. 

IDNF shall be set to one if SMART data sector’s ID field could not be found or data structure 
checksum occurred. 

ABRT shall be set to one if this command is not supported, if SMART is not enabled, or if register 
values are invalid. ABRT may be set to one if the device is not able to complete the action 
requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one indicating that the device is capable of receiving any command. 

DF (Device Fault) shall be set to one indicating that a device fault has occurred. 

DRQ shall be cleared to Zero indicating that there is no data to be transferred. 

ERR shall be set to one if any Error register bit is set to one. 


6.54.5.7 Prerequisites 

DRDY set to one. SMART enabled. 

6.54.5.8 Description 

This command returns the Device SMART data structure to the host. 


Table 49 defines the 512 bytes that make up the Device SMART data structure. All multi-byte fields shown 
in this structure follow the byte ordering described in Volume 1, Clause 3. 
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Table 49 - Device SMART data structure 


| Byte | FIV| Descriptions 


Error logging capability 
7-1 Reserved 
0 1=Device error logging supported 


375-385] Reserved 
Key: 
F=the content of the byte is fixed and does not change. 
V=the content of the byte is variable and may change depending on the state of the 
device or the commands executed by the device. 
X=the content of the byte is vendor specific and may be fixed or variable. 
R=the content of the byte is reserved and shall be zero. 


6.54.5.9 Off-line collection status byte 


The value of the off-line data collection status byte defines the current status of the off-line activities of the 
device. Table 50 lists the values and their respective definitions. 


Table 50 - Off-line data collection status byte values 


6.54.5.10 Self-test execution status byte 
The self-test execution status byte reports the execution status of the self-test routine. 
— Bits (3:0) (Percent Self-Test Remaining) The value in these bits indicates an approximation of 
the percent of the self-test routine remaining until completion in ten percent increments. Valid 
values are 9 through 0. A value of 0 indicates the self-test routine is complete. A value of 9 
indicates 90% of total test time remaining. 
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— Bits (7:4) (Self-test Execution Status) The value in these bits indicates the current Self-test 
Execution Status (See Table 51). 


Table 51 - Self-test execution status values 
[0 _| The previous self-test routine completed without error orno self-testhaseverbeenrun | 
[2 | The selFtest routine was inlerupied by the host with a hardware orsofware reset | 


A fatal error or unknown test error occurred while the device was executing its self-test 
routineand the device was unable to complete the self-test routine. 

The previous self-test completed having a test element that failed and the test element that 
failed is not known. 


The previous self-test completed having the electrical element of the test failed. 
| 6 _ | The previous self-test completed having the servo (and/or seek) test element of the test failed. 
The previous self-test completed having the read element of the test failed. 


The previous self-test completed having a test element that failed and the device is suspected 
of having handling damage. 
Self-test routine in progress. 


6.54.5.11 Total time to complete off-line data collection 


The total time in seconds to complete off-line data collection activity word specifies how many seconds the 
device requires to complete the sequence of off-line data collection activity. Valid values for this word are 
from 0001h to FFFFh. 


6.54.5.12 Off-line data collection capabilities 


The following describes the definition for the off-line data collection capability bits. If the value of all of these 
bits is cleared to zero, then no off-line data collection is implemented by this device. 


— Bit O (EXECUTE OFF-LINE IMMEDIATE implemented bit) - If this bit is set to one, then the SMART 
EXECUTE OFF-LINE IMMEDIATE command is implemented by this device. If this bit is cleared to zero, 
then the SMART EXECUTE OFF-LINE IMMEDIATE command is not implemented by this device. 


— Bit 1 (vendor specific). 


— Bit 2 (abort/restart off-line by host bit) - If this bit is set to one, then the device shall abort all off-line data 
collection activity initiated by an SMART EXECUTE OFF-LINE IMMEDIATE command upon receipt of a 
new command within 2 seconds of receiving the new command. If this bit is cleared to zero, the device 
shall suspend off-line data collection activity after an interrupting command and resume off-line data 
collection activity after some vendor-specified event. 


— Bit 3 (off-line read scanning implemented bit) - If this bit is cleared to zero, the device does not support 
off-line read scanning. If this bit is set to one, the device supports off-line read scanning. 


— Bit 4 (Self-test implemented bit) - If this bit is cleared to zero, the device does not implement the Short 
and Extended self-test routines. If this bit is set to one, the device implements the Short and Extended 
self-test routines. 


— Bit 5 (conveyance self-test implemented bit) - If this bit is cleared to zero, the device does not implement 
the Conveyance self-test routines. If this bit is set to one, the device implements the Conveyance self- 
test routines. 


— Bit 6 (Selective self-test implemented bit) - If this bit is cleared to zero, the device does not implement the 
Selective self-test routine. If this bit is set to one, the device implements the Selective self-test routine. 
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— Bit 7 (Reserved). 

6.54.5.13 SMART capablilities 

The following describes the definition for the SMART capabilities bits. 

-— BitO - If this bit is set to one, the device saves SMART data prior to going into a power saving mode 
(Idle, Standby, or Sleep) or immediately upon return to Active or Idle mode from a Standby mode. If this 
bit is cleared to zero, the device does not save SMART data prior to going into a power saving mode 


(Idle, Standby, or Sleep) or immediately upon return to Active or Idle mode from a Standby mode. 


— Bit 1 - This bit shall be set to one to indicate that the device supports the SMART ENABLE/DISABLE 
ATTRIBUTE AUTOSAVE command. 


— Bits (15:2) (Reserved). 

6.54.5.14 Self-test routine recommended polling time 

The self-test routine recommended polling time shall be equal to the number of minutes that is the minimum 
recommended time before which the host should first poll for test completion status. Actual test time could 
be several times this value. Polling before this time could extend the self-test execution time or abort the test 
depending on the state of bit 2 of the off-line data capability bits. 

6.54.5.15 Data structure checksum 

The data structure checksum is the two's complement of the sum of the first 511 bytes in the data structure. 
Each byte shall be added with unsigned arithmetic, and overflow shall be ignored. The sum of all 512 bytes 
will be zero when the checksum is correct. The checksum is placed in byte 511. 

6.54.6 SMART READ LOG 

6.54.6.1 Command code 

BOh with the content of the Features register equal to D5h. 

6.54.6.2 Feature set 

SMART feature set. 


— Optional when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.6.3 Protocol 

PIO data-in (See Clause 11). 

6.54.6.4 Inputs 

The Features register shall be set to D5h. The Sector Count register shall specify the number of sectors to 


be read from the log number specified by the LBA Low register. The LBA Mid register shall be set to 4Fh. 
The LBA High register shall be set to C2h. 
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| Register | 7 OT 6 | CT Tt fT 


Sector count -specifies the number of sectors to be read from the specified log. The log transferred by the 
drive shall start at the first sector in the specified log, regardless of the sector count requested. 


LBA Low - specifies the log to be returned as described in Table 52. If this command is implemented, all 
address values for which the contents are defined shall be implemented and all address values defined 
as host vendor specific shall be implemented. The host vendor specific logs may be used by the host 
to store any data desired. If a host vendor specific log has never been written by the host, when read 
the content of the log shall be zeros. Device vendor specific logs may be used by the device vendor to 
store any data and need only be implemented if used. 


Table 52 - Log address definition 


POOH eT CLogirectory | CRO 
PH Summary SMARTerrorlog | RO 
o2h | Comprehensive SMART errorlog | RO 

Po OHH SMART self-testlog | RO 
Device vendor specific 

Key — 

RO - Log is read only by the host. 

R/W - Log is read or written by the host. 

VS - Log is vendor specific thus read/write abiltiy is vendor specific. 


NOTE - Log addresses 03h, 07h, 20h, 21h , 22h, and 23h are used by the READ LOG 
EXT and WRITE LOG EXT commands. If these log addresses are used with the 
SMART READ LOG command, the device shall return command aborted. 


Device register - 
DEV shall specify the selected device. 
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6.54.6.5 Normal outputs 


| Register | 7] OT 6 | a ft 
| Features Pa 
| SectorCount, Pn 
Pp LBALow Pn 


Pp LBAMig Pa 
We = SBA BGi eS See 
pp Davies obs) na | obs) DEV | = a 
| Status | BSY | DRDY | DF | na | DRQ | na | na _[ ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.54.6.6 Error outputs 


If the device does not support this command, if SMART is disabled, or if the values in the Features, LBA 
Low, Sector Count, LBA Mid, or LBA High registers are invalid, the device shall return command aborted. If 
the host issues a SMART READ LOG or SMART WRITE LOG command with a Sector Count value of zero, 
the device shall return command aborted. 


| Register | 7 |] 6 | a 
Pp Error =| Sma S| UNC | na_| INF | na_| ABRT | na _ | obs | 
fe etOr COUN I ne 
Pp LBALow Pn 

——— ee ee 


[Weve I aiens na | oe EE ee 
satus [ss prov | br} na OR ne] na 


Error register - 

UNC shall be set to one if SMART log sector is uncorrectable. 

IDNF shall be set to one if SMART log sector’s ID field was not found or data structure checksum 
error occurred. 

ABRT shall be set to one if this command is not supported, if SMART is not enabled, if the log sector 
address is not implemented, if the Sector Count value is zero, or if other register values are 
invalid. ABRT may be set to one if the device is not able to complete the action requested by 
the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one indicating that the device is capable of receiving any command. 

DF (Device Fault) shall be set to one indicating that a device fault has occurred. 

DRQ shall be cleared to Zero indicating that there is no data to be transferred. 

ERR shall be set to one if any Error register bit is set to one. 


6.54.6.7 Prerequisites 


DRDY set to one. SMART enabled. 
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6.54.6.8 Description 
This command returns the specified log to the host. 
6.54.6.8.1 SMART Log Directory 


Table 53 defines the 512 bytes that make up the SMART Log Directory, which is optional. If implemented, 
the SMART Log Directory is SMART Log address zero, and is defined as one sector long. 


Table 53 - SMART Log Director 


|__Byte | Descriptions 


Number of sectors in the log at log address 2 


fein ee see ee 
Number of sectors in the log at log address 255 


The value of the SMART Logging Version word shall be 01h if the drive supports multi-sector SMART logs. 
In addition, if the drive supports multi-sector logs, then the logs at log addresses 80-9Fh shall each be 
defined as 16 sectors long. 


If the drive does not support multi-sector SMART logs, then log number zero is defined as reserved, and the 
drive shall return a command aborted response to the host’s request to read log number zero. 


6.54.6.8.2_ Summary error log sector 


Table 54 defines the 512 bytes that make up the SMART summary error log sector. All multi-byte fields 
shown in this structure follow the byte ordering described in Volume 1, Clause 3. Summary error log data 
structures shall include UNC errors, IDNF errors for which the address requested was valid, servo errors, 
write fault errors, etc. Summary error log data structures shall not include errors attributed to the receipt of 
faulty commands such as command codes not implemented by the device or requests with invalid 
parameters or invalid addresses. If the device supports comprehensive error log (address 02h), then the 
summary error log sector duplicates the last five error entries in the comprehensive error log. The summary 
error log Supports 28-bit addressing only. 


Table 54 - SMART summary error log sector 
| 0 | SMARTerrorlogversion 


6.54.6.8.2.1 Error log version 


The value of the SMART summary error log version byte shall be O1h. 
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6.54.6.8.2.2 Error log index 


The error log index indicates the error log data structure representing the most recent error. Only values 5 
through 0 are valid. If there are no error log entries, the value of the error log index shall be zero. 


6.54.6.8.2.3 Error log data structure 


An error log data structure shall be presented for each of the last five errors reported by the device. These 
error log data structure entries are viewed as a circular buffer. That is, the first error shall create the first error 
log data structure; the second error, the second error log structure; etc. The sixth error shall create an error 
log data structure that replaces the first error log data structure; the seventh error replaces the second error 
log structure, etc. The error log pointer indicates the most recent error log structure. If fewer than five errors 
have occurred, the unused error log structure entries shall be zero filled. Table 55 describes the content of a 
valid error log data structure. 


Table 55 - Error log data structure 


6.54.6.8.2.3.1 Command data structure 


The fifth command data structure shall contain the command or reset for which the error is being reported. 
The fourth command data structure should contain the command or reset that preceded the command or 
reset for which the error is being reported, the third command data structure should contain the command or 
reset preceding the one in the fourth command data structure, etc. If fewer than four commands and resets 
preceded the command or reset for which the error is being reported, the unused command data structures 
shall be zero filled, for example, if only three commands and resets preceded the command or reset for 
which the error is being reported, the first command data structure shall be zero filled. In some devices, the 
hardware implementation may preclude the device from reporting the commands that preceded the 
command for which the error is being reported or that preceded a reset. In this case, the command data 
structures are zero filled. 


If the command data structure represents a command or software reset, the content of the command data 
structure shall be as shown in Table 56. If the command data structure represents a hardware reset, the 
content of byte n shall be FFh, the content of bytes n+1 through n+7 are vendor specific, and the content of 
bytes n+8 through n+11 shall contain the timestamp. 
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Table 56 - Command data structure 


| Byte | Descriptions 
Content of the Device Control register when the Command register was written. 


Content of the Features register when the Command register was written. 
Content of the Sector Count register when the Command register was written. 
Content of the LBA Low register when the Command register was written. 


Content of the LBA Mid register when the Command register was written. 


Timestamp shall be the time since power-on in milliseconds when command acceptance occurred. This 
timestamp may wrap around. 


6.54.6.8.2.3.2 Error data structure 


The error data structure shall contain the error description of the command for which an error was reported 
as described in Table 57. If the error was logged for a hardware reset, the content of bytes n+1 through n+7 
shall be vendor specific and the remaining bytes shall be as defined in Table 57. 


Table 57 - Error data structure 


Extended error information shall be vendor specific. 


State shall contain a value indicating the state of the device when command was written to the Command 
register or the reset occurred as described in Table 58. 


Table 58 - State field values 


| Value | State 


Active/idle with BSY cleared to zero 
Executing SMART off-line or self-test 
Reserved 

Vendor unique 


The value of x is vendor specific and may be different for each state. 
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Sleep indicates the reset for which the error is being reported was received when the device was in the 
Sleep mode. 


Standby indicates the command or reset for which the error is being reported was received when the device 
was in the Standby mode. 


Active/Idle with BSY cleared to zero indicates the command or reset for which the error is being reported was 
received when the device was in the Active or Idle mode and BSY was cleared to zero. 


Executing SMART off-line or self-test indicates the command or reset for which the error is being reported 
was received when the device was in the process of executing a SMART off-line or self-test. 


Life timestamp shall contain the power-on lifetime of the device in hours when command completion 
occurred. 


6.54.6.8.2.4 Device error count 


The device error count field shall contain the total number of errors attributable to the device that have been 
reported by the device during the life of the device. These errors shall include UNC errors, IDNF errors for 
which the address requested was valid, servo errors, write fault errors, etc. This count shall not include errors 
attributed to the receipt of faulty commands such as commands codes not implemented by the device or 
requests with invalid parameters or invalid addresses. If the maximum value for this field is reached, the 
count shall remain at the maximum value when additional errors are encountered and logged. 


6.54.6.8.2.5 Data structure checksum 


The data structure checksum is the two's complement of the sum of the first 511 bytes in the data structure. 
Each byte shall be added with unsigned arithmetic, and overflow shall be ignored. The sum of all 512 bytes 
will be zero when the checksum is correct. The checksum is placed in byte 511. 


6.54.6.8.3 Comprehensive error log 


Table 59 defines the format of each of the sectors that comprise the SMART comprehensive error log. The 
SMART Comprehensive error log provides logging for 28-bit addressing only. For 48-bit addressing See 
6.31.8.2. The maximum size of the SMART comprehensive error log shall be 51 sectors. Devices may 
support fewer than 51 sectors. All multi-byte fields shown in this structure follow the byte ordering described 
in volume 1, Clause 3. The comprehensive error log data structures shall include UNC errors, IDNF errors for 
which the address requested was valid, servo errors, write fault errors, etc. Comprehensive error log data 
structures shall not include errors attributed to the receipt of faulty commands such as command codes not 
supported by the device or requests with invalid parameters or invalid addresses. 


Table 59 - Comprehensive error log 


First sector Subsequent sectors 
SMART error log version Reserved 
Error log index Reserved 

2-91 First error log data structure Data structure 5n+1 
92-181 Second error log data structure | Data structure 5n+2 
182-271 Third error log data structure Data structure 5n+3 


272-361 Fourth error log data structure Data structure 5n+4 
362-451 Fifth error log data structure Data structure 5n+5 
452-453 Device error count Reserved 
454-510 Reserved Reserved 

511 Data structure checksum Data structure checksum 


n is the sector number within the log. The first sector is sector zero 
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6.54.6.8.3.1 Error log version 

The value of the error log version byte shall be set to O1h. 

6.54.6.8.3.2 Error log index 

The error log index indicates the error log data structure representing the most recent error. If there have 
been no error log entries, the error log index is set to zero. Valid values for the error log index are zero to 
255. 

6.54.6.8.3.3 Error log data structure 

The error log is viewed as a circular buffer. The device may support from two to 51 error log sectors. When 
the last supported error log sector has been filled, the next error shall create an error log data structure that 
replaces the first error log data structure in sector zero. The next error after that shall create an error log data 
structure that replaces the second error log data structure in sector zero. The sixth error after the log has 


filled shall replace the first error log data structure in sector one, and so on. 


The error log index indicates the most recent error log data structure. Unused error log data structures shall 
be filled with zeros. 


The content of the error log data structure entries is defined in 6.54.6.8.2.3. 

6.54.6.8.3.4 Device error count 

The device error count field is defined in 6.54.6.8.2.4. 

6.54.6.8.3.5 Data structure checksum 

The data structure checksum is defined in 6.54.6.8.2.5. 

6.54.6.8.4 Self-test log sector 

Table 60 defines the 512 bytes that make up the SMART self-test log sector. All multi-byte fields shown in 


this structure follow the byte ordering described in Volume 1, Clause 3. The self-test log sector supports 28- 
bit addressing only. 


Table 60 - Self-test log data structure 
DROP (PPP 


This log is viewed as a circular buffer. The first entry shall begin at byte 2, the second entry shall begin at 
byte 26, and so on until the twenty-second entry, that shall replace the first entry. Then, the twenty-third 
entry shall replace the second entry, and so on. If fewer than 21 self-tests have been performed by the 
device, the unused descriptor entries shall be filled with zeroes. 
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6.54.6.8.4.1 Self-test log data structure revision number 

The value of the self-test log data structure revision number shall be 0001h. 
6.54.6.8.4.2 Self-test log descriptor entry 

The content of the self-test descriptor entry is shown in Table 61. 


Table 61 - Self-test log descriptor entr 


n+6 
n+7 
n+8 

[Vendor specific. 


n+9 ton+23 | Vendor specific. 


Content of the LBA Low register shall be the content of the LBA Low register when the nth self-test 
subcommand was issued (See 6.54.4.8). 


Content of the self-test execution status byte shall be the content of the self-test execution status byte when 
the nth self-test was completed (See 6.54.5.10). 


Life timestamp shall contain the power-on lifetime of the device in hours when the nth self-test subcommand 
was completed. 


Content of the self-test failure checkpoint byte may contain additional information about the self-test that 
failed. 


The failing LBA shall be the LBA of the uncorrectable sector that caused the test to fail. If the device 
encountered more than one uncorrectable sector during the test, this field shall indicate the LBA of the first 
uncorrectable sector encountered. If the test passed or the test failed for some reason other than an 
uncorrectable sector, the value of this field is undefined. 


6.54.6.8.4.3 Self-test index 

The self-test index shall point to the most recent entry. Initially, when the log is empty, the index shall be set 
to zero. It shall be set to one when the first entry is made, two for the second entry, etc., until the 22nd entry, 
when the index shall be reset to one. 

6.54.6.8.4.4 Data structure checksum 

The data structure checksum is the two's complement of the sum of the first 511 bytes in the data structure. 
Each byte shall be added with unsigned arithmetic, and overflow shall be ignored. The sum of all 512 bytes 
is zero when the checksum is correct. The checksum is placed in byte 511. 

6.54.6.8.5 Selective self-test log 

The Selective self-test log is a log that may be both written and read by the host. This log allows the host to 


select the parameters for the self-test and to monitor the progress of the self-test. Table 62 defines the 
content of the Selective self-test log. 
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Table 62 - Selective self-test log 


i eyier “i Desetphon =a ss 2 ee Readinnte =) 
| 29 (| Starting LBAfortestspand CR 
RW 


6.54.6.8.5.1 Data structure revision number 


The value of the data structure revision number filed shall be 01h. This value shall be written by the host and 
returned unmodified by the device. 


6.54.6.8.5.2 Test span definition 


The Selective self-test log provides for the definition of up to five test spans. The starting LBA for each test 
span is the LBA of the first sector tested in the test span and the ending LBA for each test span is the last 
LBA tested in the test span. If the starting and ending LBA values for a test span are both zero, a test span is 
not defined and not tested. These values shall be written by the host and returned unmodified by the device. 


6.54.6.8.5.3 Current LBA under test 

The Current LBA under test field shall be written with a value of zero by the host. As the self-test progresses, 
the device shall modify this value to contain the beginning LBA of the 65,536 sector block currently being 
tested. When the self-test including the off-line scan between test spans has been completed, a zero value is 
placed in this field. 

6.54.6.8.5.4 Current span under test 

The Current span under test field shall be written with a value of zero by the host. As the self-test 
progresses, the device shall modify this value to contain the test span number of the current span being 
tested. If an off-line scan between test spans is selected, a value greater then five is placed in this field 
during the off-line scan. When the self-test including the off-line scan between test spans has been 
completed, a zero value is placed in this field. 

6.54.6.8.5.5 Feature flags 


The Feature flags define the features of Selective self-test to be executed (See Table 63). 
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Table 63 - Selective self-test feature flags 
| Bit |Description 
Vendor specific 


When set to one, perform off-line scan after selective test. 


When set to one, off-line scan after selective test is pending. 
When set to one, off-line scan after selective test is active. 


Bit (1) shall be written by the host and returned unmodified by the device. Bits (4:3) shall be written as zeros 
by the host and the device shall modify them as the test progresses. 


pe Oh | 
fe as == 
| 2 | Vendor specific 
| 38 
| 4 


1 
2 
3 
4 
=f 


6.54.6.8.5.6 Selective self-test pending time 

The selective self-test pending time is the time in minutes from power-on to the resumption of the off-line 
testing if the pending bit is set. At the expiration of this time, sets the active bit to one, and resumes the off- 
line scan that had begun before power-down. 

6.54.6.8.5.7 Data structure checksum 

The data structure checksum is defined in 6.54.6.8.2.5. 

6.54.7 SMART RETURN STATUS 

6.54.7.1 Command code 

BOh with a Feature register value of DAh. 

6.54.7.2 Feature set 


SMART feature set. 


— Mandatory when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.7.3 Protocol 
Non-data (See Clause 11). 
6.54.7.4 Inputs 


The Features register shall be set to DAh. The LBA Mid register shall be set to 4Fh. The LBA High register 
shall be set to C2h. 


| Register | 7] OT 6 OT 5 a fT 


Device register - 
DEV shall specify the selected device. 
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6.54.7.5 Normal outputs 


If the device has not detected a threshold exceeded condition, the device sets the LBA Mid register to 4Fh 
and the LBA High register to C2h. If the device has detected a threshold exceeded condition, the device sets 
the LBA Mid register to F4h and the LBA High register to 2Ch. 


| Register | 7] 6 Sa 
a 1 1” 
| SectorCount, Pn 


eer gene 
Bsy_ [| DRDY | DF | na | ORQ {na | na_| ERR | 


LBA Mid - 

AFh if threshold not exceeded, F4h if threshold exceeded. 
LBA High - 

C2h if threshold not exceeded, 2Ch if threshold exceeded. 
Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.54.7.6 Error outputs 


If the device does not support this command, if SMART is disabled, or if the values in the Features, LBA Mid, 
or LBA High registers are invalid, the device shall return command aborted. 


| Register | 7 | ST a a 
——— ee ee 


— he a $a $= 
| Status | BSY | DRDY | DF | na_| ORQ | na | na_{ ERR | 


Error register - 

ABRT shall be set to one if this command is not supported, if SMART is disabled, or if the input 
register values are invalid. ABRT may be set to one if the device is not able to complete the 
action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. 
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6.54.7.7 Prerequisites 

DRDY set to one. SMART enabled. 

6.54.7.8 Description 

This command causes the device to communicate the reliability status of the device to the host. If a threshold 
exceeded condition is not detected by the device, the device shall set the LBA Mid register to 4Fh and the 
LBA High register to C2h. If a threshold exceeded condition is detected by the device, the device shall set 
the LBA Mid register to F4h and the LBA High register to 2Ch. 

6.54.8 SMART WRITE LOG 

6.54.8.1 Command code 

BOh with the content of the Features register equal to D6h. 

6.54.8.2 Feature set 

SMART feature set. 


— Optional when the SMART feature set is implemented. 
— Use prohibited when the PACKET Command feature set is implemented. 


6.54.8.3 Protocol 

PIO data-out (See Clause 11). 

6.54.8.4 Inputs 

The Features register shall be set to D6h. The Sector Count register shall specify the number of sectors that 


shall be written to the log number specified by the LBA Low register. The LBA Mid register shall be set to 
4Fh. The LBA High register shall be set to C2h. 


| Register | 7] OT 6 | a 
[a= reales aS ee OO 8 


LBA Mid 
LBA High 
|_____Device __{ obs _| na __| obs | DEV [ina 


Sector count -specifies the number of sectors that shall be written to the specified log. The log transferred to 
the drive shall be stored by the drive starting at the first sector in the specified log. 


LBA Low - specifies the log to be written as described in Table 52. If this command is implemented, all 
address values defined as host vendor specific shall be implemented. 


Device register - 
DEV shall specify the selected device. 
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6.54.8.5 Normal outputs 


| Register | 7] OT 6 a a 
| Features Pa 
| SectorCount. Pn 
Pp LBALow Pn 


pO LBAMig Pa 
[EBA Rigi. = i a 
| Device | obs | oma_—| sobs | DEV | na 
| Status | BSY | DRDY | DF | na | DRQ | na | na _[ ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.54.8.6 Error outputs 
If the device does not support this command, if SMART is disabled, or if the values in the Features, LBA 


Low, Sector Count, LBA Mid, or LBA High registers are invalid, the device shall return command aborted. If 
the host attempts to write to a read only (RO) log address, the device shall return command aborted. 


| Register | 7] 6 a 
| Error S| Cnt S| na] Sona] DNF | na_| ABRT | na _ | obs | 
| SectorCount Pm 
Pp LBALow Pn 

——— 


[= seieer —— teeta sna th one Se a 
-=—siatus— [sy prov | br | na OR | na ER 


Error register - 

IDNF shall be set to one if SMART log sector's ID field could not be found. 

ABRT shall be set to one if this command is not supported, if SMART is not enabled, if the log sector 
address is not implemented, or if other register values are invalid. ABRT may be set to one if 
the device is not able to complete the action requested by the command. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one indicating that the device is capable of receiving any command. 

DF (Device Fault) shall be set to one indicating that a device fault has occurred. 

DRQ shall be cleared to zero indicating that there is no data to be transferred. 

ERR shall be set to one if any Error register bit is set to one. 


6.54.8.7 Prerequisites 
DRDY set to one. SMART enabled. 
6.54.8.8 Description 


This command writes an specified number of 512 byte data sectors to the specified log. 
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6.55 STANDBY 

6.55.1 Command code 

E2h 

6.55.2 Feature set 

Power Management feature set. 
— This command is mandatory for devices not implementing the PACKET Command feature set. 
— Power Management feature set is mandatory when power management is not implemented by 

the PACKET command set implemented by the device. 

— This command is mandatory when the Power Management feature set is implemented. 

6.55.3 Protocol 

Non-data (See Clause 11). 

6.55.4 Inputs 


The value in the Sector Count register when the STANDBY command is issued shall determine the time 
period programmed into the Standby timer. Table 19 defines these values. 


| Register, | 7] OT G6 TS a a 


Device register - 
DEV shall specify the selected device. 


6.55.5 Normal outputs 


Error 


Sector Count 
LBA Low 


LBA Mid 


LBA High 
Status | BsY | DRDY [| DF | na | ORQ | na | na _{ ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.55.6 Error outputs 


The device shall return command aborted if the device does not support the Power Management feature set. 


| Register | 7] |] G6 | Sa a 
| Error S| Crna S| ona =O] ma =] na | Sna_—| ABRT | na | na _ | 
p= Sector Coit, fl ig 
pC LBALow Pn 

—— re 


0 ee ea a aT 
satus [sy bry [br [na OR | ne 


Error register - 

ABRT shall be set to one if the Power Management feature set is not supported. ABRT may be set to 

one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.55.7 Prerequisites 

DRDY set to one. 

6.55.8 Description 

This command causes the device to enter the Standby mode. 


If the Sector Count register is non-zero then the Standby timer shall be enabled. The value in the Sector 
Count register shall be used to determine the time programmed into the Standby timer (See Table 19). 


If the Sector Count register is zero then the Standby timer is disabled. 
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6.56 STANDBY IMMEDIATE 

6.56.1 Command code 

EOh 

6.56.2 Feature set 

Power Management feature set. 
— This command is mandatory for devices not implementing the PACKET Command feature set. 
— Power Management feature set is mandatory when power management is not implemented by 

the PACKET command set implemented by the device. 

— This command is mandatory when the Power Management feature set is implemented. 

6.56.3 Protocol 

Non-data (See Clause 11). 


6.56.4 Inputs 


| Register | 7] | UT a CT 


Device register - 
DEV shall specify the selected device. 


6.56.5 Normal outputs 


[a a Fae ae ee Sa a 


a 


| BsY | DRDY | DF | na | ORQ | na | _na_{ ERR | 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.56.6 Error outputs 


The device shall return command aborted if the device does not support the Power Management feature set. 


| Register | 7] | G6 | a a 
p Error S| Cn S| ona SO] ma—S] ma =| Sma] ABRT | na | na _ | 
p — SSec10r Coulis = oll ia 
Pp LBALow Pn 


Pp LBAMig Pa 
po EBA Hight fia 
po Deviee— [cobs |) ha — | obs.) DEW | ay | 
| Status | BSY | DRDY | DF | na | ORQ | na | _na_{ ERR | 


Error register - 

ABRT shall be set to one if the Power Management feature set is not supported. ABRT may be set to 

one if the device is not able to complete the action requested by the command. 

Device register - 

DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.56.7 Prerequisites 
DRDY set to one. 
6.56.8 Description 


This command causes the device to immediately enter the Standby mode. 
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6.57 WRITE BUFFER 
6.57.1 Command code 
E8h 

6.57.2 Feature set 
General feature set 


— Optional for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.57.3 Protocol 
PIO data-out (See Clause 11). 


6.57.4 Inputs 


| Register | 7] OT ST a Tt 


LBA Mid 
LBA High n 


Command 


Device register - 
DEV shall specify the selected device. 


6.57.5 Normal outputs 


| Register | 7] | 6 OT a Tt 


LBA Mid 
LBA High na 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.57.6 Error outputs 


The device shall return command aborted if the command is not supported. 


Page 307 


T13/1532D Volume 1 Revision 4b 


| Register | 7 | | | a 
——— 


[-—— Bevieg [ais [na obs Br 
= siatus [sy prov [or [na ORT na | na 


Error register - 
ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 
ERR shall be set to one if an Error register bit is set to one. 


6.57.7 Prerequisites 

DRDY set to one. 

6.57.8 Description 

This command enables the host to write the contents of one sector in the device’s buffer. 


The READ BUFFER and WRITE BUFFER commands shall be synchronized within the device such that 
sequential WRITE BUFFER and READ BUFFER commands access the same 512 bytes within the buffer. 
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6.58 WRITE DMA 
6.58.1 Command code 
CAh 

6.58.2 Feature set 
General feature set 


— Mandatory for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.58.3 Protocol 
DMA (See Clause 11). 
6.58.4 Inputs 


The LBA Mid, LBA High, Device, and LBA Low specify the starting sector address to be written. The Sector 
Count register specifies the number of sectors to be transferred. 


| Register | 7] 6 | ST a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.58.5 Normal outputs 


| Register | 7] | 6 OT a fT 
i EMO ae | ee ees 


Sector Count 


na 
LBA Low 


LBA Mid 

LBA High 
Device 
Status | BsY_ | DRDY | DF | na | ORQ | na | _ina_{ ERR _| 
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Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.58.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register |] 7 | 6 | | a ft 


| Status | SY [ DRDY | DF | na_ | ORQ | na | na_[ ERR | 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one; however, if SE is set to one, ERR shall 
be cleared to zero. 


6.58.7 Prerequisites 


DRDY set to one. The host shall initialize the DMA channel. 
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6.58.8 Description 


The WRITE DMA command allows the host to write data using the DMA data transfer protocol. 
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6.59 WRITE DMA EXT 
6.59.1 Command code 
35h 

6.59.2 Feature set 

48-bit Address feature set 


— Mandatory for devices implementing the 48-bit Address feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.59.3 Protocol 
DMA (See Clause 11). 


6.59.4 Inputs 


Register sf Se a ae ee  _ 
Features Current Reserved 

Previous Reserved 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current 

Previous 


Previous LBA (39:32 
Previous LBA (47:40 


NOTE -— The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous Is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). OO000h in the Sector Count register 
specifies that 65,536 sectors are to be transferred. 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.59.5 Normal outputs 


pRegister CT CT a Bt 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.59.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register = 7 es a 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 
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Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. however, if SE is set to one, ERR shall 

be cleared to zero. 


6.59.7 Prerequisites 
DRDY set to one. The host shall initialize the DMA channel. 
6.59.8 Description 


The WRITE DMA EXT command allows the host to write data using the DMA data transfer protocol. 
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6.60 WRITE DMA FUA EXT 
6.60.1 Command code 

3Dh 

6.60.2 Feature set 

48-bit Address feature set 


— Optional for devices implementing the 48-bit Address feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.60.3 Protocol 
DMA (See Clause 11). 


6.60.4 Inputs 


Register, =| 7 | 6 LC] S| A] CT 2 
Features Current Reserved 
Previous Reserved 
Sector Count | Current Sector count (7:0) 
Previous Sector count (15:8) 
LBA Low Current LBA (7:0) 
Previous LBA (31:24) 
LBA Mid Current LBA (15:8) 
Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40 


3Dh 


NOTE -— The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous Is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). O000h in the Sector Count register 
specifies that 65,536 sectors are to be transferred. 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.60.5 Normal outputs 


pRegister CT 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.60.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


[Register | 7 UT CUT CUT aA sc Ta 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 
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Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.60.7 Prerequisites 

DRDY set to one. The host shall initialize the DMA channel. 

6.60.8 Description 

The WRITE DMA FUA EXT command provides the same function as the WRITE DMA EXT command except 


that regardless of whether write caching in the device is enabled or not, the user data shall be written to the 
media before ending status for the command is reported. 
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6.61 WRITE DMA QUEUED 
6.61.1 Command code 
CCh 
6.61.2 Feature set 
Overlapped feature set 
— Mandatory for devices implementing the Overlapped feature set and not implementing the 
PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 
6.61.3 Protocol 


DMA QUEUED (See Clause 11). 


6.61.4 Inputs 


| Register | 7] OT 6 OT 5 a fT 
Sector Count 


LBA Mid LBA ae 8) 
LBA High LBA (23:16) 
| CiDevice ~———CSs|_sobs’ | ~LBA | obs | DEV | LBA (27:24) 
P Command 


Features - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
Sector count - 
if the device supports command queuing, bits (7:3) contain the Tag for the command being 
delivered. A Tag value may be any value between O and 31 regardless of the queue depth 
supported. If queuing is not supported, this field is not applicable. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.61.5 Normal outputs 
6.61.5.1 Data transmission 
Data transfer may occur after receipt of the command or may occur after the receipt of a SERVICE 


command. When the device is ready to transfer data requested by a data transfer command, the device sets 
the following register content to initiate the data transfer. 
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| Register | 7 OT 6 OT a CT 
Pp LBALow Pa 


na 
| Status | BSY | DRDY | DF | SERV | DRQ | na | na _ [CHK _| 


Interrupt reason register - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
O and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this field is not applicable. 
REL - Shall be cleared to zero. 
I/O - Shall be cleared to zero indicating the transfer is from the host. 
C/D - Shall be cleared to zero indicating the transfer of data. 
Device register - 
DEV - Shall indicate the selected device. 
Status register - 
BSY - Shall be cleared to zero. 
DRDY - Shall be set to one. 
DF (Device Fault) - Shall be cleared to zero. 
SERV (Service) - Shall be set to one if another command is ready to be serviced. 
DRQ - Shall be set to one. 
CHK - Shall be cleared to zero. 


6.61.5.2 Bus release 


If the device performs a bus release before transferring data for this command, the register content upon 
performing a bus release shall be as shown below. 


| Register | 7] OT ST a 


na 
| Status | SY | DRDY [| DF | SERV | DRQ | na | na_| ERR _| 


Sector Count register - 

Tag - If the device supports command queuing, this field shall contain the Tag of the command being 
bus released. If the device does not support command queuing, this field shall be zeros. 

REL bit shall be set indicating that the device has bus released an overlap command. 

I/O shall be cleared to zero. 

C/D shall be cleared to zero. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating bus release. 

DRDY shall be set to one. 

SERV (Service) shall be cleared to zero if no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. This bit shall be set 
to one when the device has prepared this command for service. 

DF (Device Fault) shall be cleared to zero. 

DRQ bit shall be cleared to zero. 

ERR bit shall be cleared to zero. 
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6.61.5.3 Service request 


When the device is ready to transfer data or complete a command after the command has performed a bus 
release, the device shall set the SERV bit and not change the state of any other register bit (See Clause 10). 
When the SERVICE command is received, the device shall set outputs as described in data transfer, 
command completion, or error outputs depending on the service the device requires. 


6.61.5.4 Command completion 


When the transfer of all requested data has occurred without error, the register content shall be as shown 
below. 


| Register | 7] 6 UT 5 tT 
na 


LBA Mid 
LBA High na 


PS oe Se A 
DEV 
| Status | SY | DRDY | DF | SERV | DRQ | na [_na_| 


Sector Count register - 
Tag - If the device supports command queuing, this field shall contain the Tag of the completed 
command. If the device does not support command queuing, this field shall be zeros. 
REL shall be cleared to zero. 
I/O shall be set to one. 
C/D shall be set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 
DF (Device Fault) shall be cleared to zero. 
DRQ bit shall be cleared to Zero. 
ERR bit shall be cleared to zero. 


6.61.6 Error outputs 


The Sector Count register contains the Tag for this command if the device supports command queuing. The 
device shall return command aborted if the command is not supported. The device shall return command 
aborted if the device supports command queuing and the Tag is invalid. An unrecoverable error 
encountered during the execution of this command results in the termination of the command and the 
Command Block registers contain the sector where the first unrecoverable error occurred. If a queue existed, 
the unrecoverable error shall cause the queue to abort. The device may remain BSY for some time when 
responding to these errors. 
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| Register | 7 | } CT CT a 
LBA Low 


| Status | BSY | DRDY | DF | SERV | DRQ | na | na _{ ERR | 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be. IDNF shall be set to one if an 
address outside of the range of user-accessible addresses is requested if command aborted 
is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

Sector Count register - 

Tag - If the device supports command queuing, this field shall contain the Tag of the completed 
command. If the device does not support command queuing, this field shall be zeros. 

REL shall be cleared to zero. 

I/O shall be set to one. 

C/D shall be set to one. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.61.7 Prerequisites 

DRDY set to one. The host shall initialize the DMA channel. 

6.61.8 Description 

This command executes in a similar manner to a WRITE DMA command. The device may perform a bus 
release the bus or may execute the data transfer without performing a bus release if the data is ready to 
transfer. 

If the device performs a bus release, the host shall reselect the device using the SERVICE command. 

Once the data transfer is begun, the device shall not perform a bus release until the entire data transfer has 


been completed. 
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6.62 WRITE DMA QUEUED EXT 

6.62.1 Command code 

36h 

6.62.2 Feature set 

Overlapped feature set and 48-bit Address feature set 


— Mandatory for devices implementing the Overlapped feature set and the 48-bit Address feature 
set and not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.62.3 Protocol 
DMA QUEUED (See Clause 11). 


6.62.4 Inputs 


[Register SCT tT UT CU A CT 2 tt 
Features Current Sector count (7:0) 

Previous Sector count (15:8) 

Sector Count | Current Reserved 

Previous Reserved 

LBA Low Current 

Previous 

LBA Mid Current LBA (15:8) 

Previous LBA (39:32) 

LBA High Current LBA (23:16) 

Previous LBA (47:40 


36h 
NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Features Current - 
number of sectors to be transferred low order, bits (7:0). 
Features Previous - 
number of sectors to be transferred high order, bits (15:8). O00Oh in the Features register specifiess 
that 65,536 sectors are to be transferred. 
Sector Count Current - 
if the device supports command queuing, bits (7:3) contain the Tag for the command being 
delivered. A Tag value may be any value between O and 31 regardless of the queue depth 
supported. If queuing is not supported, this register shall be set to the value OOh. 
Sector Count Previous - 
Reserved 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
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LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 


6.62.5 Normal outputs 
6.62.5.1 Data transmission 


Data transfer may occur after receipt of the command or may occur after the receipt of a SERVICE 
command. When the device is ready to transfer data requested by a data transfer command, the device sets 
the following register content to initiate the data transfer. 


Register = ae Oe ee Aa ee ie S| 
Sector Count | HOB = 0 Tag REL /O C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be cleared to zero indicating the transfer is from the host. 
C/D - Shall be cleared to zero indicating the transfer of data. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.62.5.2 Bus release 


If the device performs a bus release before transferring data for this command, the register content upon 
performing a bus release shall be as shown below. 
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pRegister Cd CZ UT UT A 2 
Sector Count | HOB = 0 Tag REL /0 C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 

REL - Shall be set to one. 

I/O - Shall be cleared to zero. 

C/D - Shall be cleared to zero indicating the transfer of data. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero. 

DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. SERV shall be set 
to one when the device has prepared this command for service. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.62.5.3 Service request 

When the device is ready to transfer data or complete a command after the command has performed a bus 
release, the device shall set the SERV bit to one and not change the state of any other register bit (See 
Clause 10). When the SERVICE command is received, the device shall set outputs as described in data 
transfer, command completion, or error outputs depending on the service the device requires. 


6.62.5.4 Command completion 


When the transfer of all requested data has occurred without error, the register content shall be as shown 
below. 
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pRegister CT ZT UT A 
Sector Count | HOB =0 Tag REL /0 C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
O and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be set to one. 
C/D - Shall be set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.62.6 Error outputs 


The Sector Count register contains the Tag for this command if the device supports command queuing. The 
device shall return command aborted if the command is not supported or if the device has not had 
overlapped interrupt enabled. The device shall return command aborted if the device supports command 
queuing and the Tag is invalid. An unrecoverable error encountered during the execution of this command 
results in the termination of the command and the Command Block registers contain the sector where the 
first unrecoverable error occurred. If a queue existed, the unrecoverable error shall cause the queue to abort. 
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[Register | TT 8 a 
Sector Count | HOB = 0 Tag REL /0 C/D 
HOB = 1 Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 

REL - Shall be cleared to zero. 

I/O - Shall be set to one. 

C/D - Shall be set to one. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
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BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 
6.62.7 Prerequisites 
DRDY set to one. The host shall initialize the DMA channel. 
6.62.8 Description 
This command executes in a similar manner to a WRITE DMA EXT command. The device may perform a 
bus release the bus or may execute the data transfer without performing a bus release if the data is ready to 
transfer. 


If the device performs a bus release, the host shall reselect the device using the SERVICE command. 


Once the data transfer is begun, the device shall not perform a bus release until the entire data transfer has 
been completed. 
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6.63 WRITE DMA QUEUED FUA EXT 
6.63.1 Command code 

3Eh 

6.63.2 Feature set 

Overlapped feature set and 48-bit Address feature set 


— Mandatory for devices implementing the Overlapped feature set and the 48-bit Address feature 
set and not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.63.3 Protocol 
DMA QUEUED (See Clause 11). 


6.63.4 Inputs 


[Register SCT tT UT CU A 2 
Features Current Sector count (7:0) 

Previous Sector count (15:8) 

Sector Count | Current Reserved 

Previous Reserved 

LBA Low Current 

Previous 

LBA Mid Current LBA (15:8) 

Previous LBA (39:32) 

LBA High Current LBA (23:16) 

Previous LBA (47:40 


3Eh 
NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Features Current - 
number of sectors to be transferred low order, bits (7:0). 
Features Previous - 
number of sectors to be transferred high order, bits (15:8). OOOOh in the Features register specifies 
that 65,536 sectors are to be transferred. 
Sector Count Current - 
if the device supports command queuing, bits (7:3) contain the Tag for the command being 
delivered. A Tag value may be any value between O and 31 regardless of the queue depth 
supported. If queuing is not supported, this register shall be set to the value OOh. 
Sector Count Previous - 
Reserved 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
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LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 


6.63.5 Normal outputs 
6.63.5.1 Data transmission 


Data transfer may occur after receipt of the command or may occur after the receipt of a SERVICE 
command. When the device is ready to transfer data requested by a data transfer command, the device sets 
the following register content to initiate the data transfer. 


Register = ae I Oe fs ee aa ee = le S| 
Sector Count | HOB = 0 Tag REL /O C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be cleared to zero indicating the transfer is from the host. 
C/D - Shall be cleared to zero indicating the transfer of data. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.63.5.2 Bus release 


If the device performs a bus release before transferring data for this command, the register content upon 
performing a bus release shall be as shown below. 
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pRegister Cd CZ UT UT A 2 
Sector Count | HOB = 0 Tag REL /0 C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 

REL - Shall be set to one. 

I/O - Shall be cleared to zero. 

C/D - Shall be cleared to zero indicating the transfer of data. 

Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero. 

DRDY shall be set to one. 

DF (Device Fault) shall be cleared to zero. 

SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. SERV shall be set 
to one when the device has prepared this command for service. 

DRQ shall be cleared to zero. 

ERR shall be cleared to zero. 


6.63.5.3 Service request 

When the device is ready to transfer data or complete a command after the command has performed a bus 
release, the device shall set the SERV bit to one and not change the state of any other register bit (See 
Clause 10). When the SERVICE command is received, the device shall set outputs as described in data 
transfer, command completion, or error outputs depending on the service the device requires. 


6.63.6 Command completion 


When the transfer of all requested data has occurred without error, the register content shall be as shown 
below. 
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pRegister CT ZT UT A 
Sector Count | HOB =0 Tag REL /0 C/D 

HOB=1 Reserved 

LBA Low Reserved 

Reserved 

LBA Mid Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
O and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 
REL - Shall be cleared to zero. 
I/O - Shall be set to one. 
C/D - Shall be set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
SERV (Service) shall be cleared to zero when no other queued command is ready for service. SERV 
shall be set to one when another queued command is ready for service. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.63.7 Error outputs 


The Sector Count register contains the Tag for this command if the device supports command queuing. The 
device shall return command aborted if the command is not supported or if the device has not had 
overlapped interrupt enabled. The device shall return command aborted if the device supports command 
queuing and the Tag is invalid. An unrecoverable error encountered during the execution of this command 
results in the termination of the command and the Command Block registers contain the sector where the 
first unrecoverable error occurred. If a queue existed, the unrecoverable error shall cause the queue to abort. 
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[Register | TT 8 a 
Sector Count | HOB = 0 Tag REL 0 C/D 
HOB = 1 Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. 
The content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

Sector Count (when HOB of the Device Control register is cleared to zero) - 
Tag -This field contains the command Tag for the command. A Tag value may be any value between 
0 and 31 regardless of the queue depth supported. If the device does not support command 
queuing or overlap is disabled, this register shall be set to the value OOh. 

REL - Shall be cleared to zero. 

I/O - Shall be set to one. 

C/D - Shall be set to one. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 
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BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 
DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.63.8 Prerequisites 
DRDY set to one. The host shall initialize the DMA channel. 
6.63.9 Description 


This command executes in a similar manner to a WRITE DMA EXT command. The device may perform a 
bus release or may execute the data transfer without performing a bus release if the data is ready to transfer. 


If the device performs a bus release, the host shall reselect the device using the SERVICE command. 


Once the data transfer is begun, the device shall not perform a bus release until the entire data transfer has 
been completed. 


The WRITE DMA QUEUED FUA EXT command provides the same function as the WRITE DMA EXT 
command. It is an Overlapped feature set command and when issued it shall not cause an existing queue to 
be aborted. However, regardless of whether write caching in the device is enabled or not, the user data shall 
be written to the media before ending status for the command is reported. 
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6.64 WRITE LOG EXT 

6.64.1 Command code 

3Fh 

6.64.2 Feature set 

General Purpose Logging feature set. 
— Mandatory for devices implementing the General Purpose Logging feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 

6.64.3 Protocol 

PIO data-out (See Clause 11). 


6.64.4 Inputs 
| CRegister | 7 |] 6 OT SC Ud] A | UT 2 UT lt 
Features Current Reserved 
Sector Count | Current Sector count (7:0) 
Pecercoun| frewous | Serorcoumm gs) 
LBA Low Current Log address 
PUPAL frewous | Resend 


LBA Mid Current Sector offset ee 
pMPAMM [Grewous | Sesronser is) 
LBA High Current Reserved 
pMPAMOY | prewmeus | Reseed 
-——Beweelead __{_obs_|_na_|_obs_|_ DEV [_Reserved 


NOTE - The value SaGHet SCC RUC EA STE PES STE as Current is the value most een written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count - Specifies the number of sectors that shall be written to the specified log. If the number is 
greater than the number indicated in the Log directory (which is available in Log number zero), the 
device shall return command aborted. The log transferred to the drive shall be stored by the drive 
starting at the first sector in the specified log. 

LBA Low - Specifies the log to be written as described in Table 20. A device may support a subset of the 
available logs. Support for individual logs is determined by support for the associated feature set. 
Support of the associated log(s) is mandatory for devices implementing the associated feature set. If 
this command is implemented, all address values defined as host vendor specific shall be 
implemented. These host vendor specific logs may be used by the host to store any data desired. 
Support for device vendor specific logs is optional. If the host attempts to write to a read only (RO) 
log address, the device shall return command aborted. 

LBA Mid - Specifies the first sector of the log to be written. 

Device/Head register - 

DEV shall specify the selected device. 
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6.64.5 Normal outputs 


[Register S| 7 UT UT CUT A tT 
ee ae Ns ee 


na 
HOB=1 Reserved 
HOB=1 Reserved 
HOB=1 Reserved 


LBA High HOB =0 Reserved 
al HOB = 1 Reserved 
Ps tetas ~~. “BSY | DRDY <BR | tas] DRO] = ina] har — TERR: | 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 


cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device/Head register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.64.6 Error outputs 
If the device does not support this command, if the feature set associated with the log specified in the LBA 
Low register is not supported or enabled, or if the values in the Features, Sector Count, LBA Mid, or LBA 


High registers are invalid, the device shall return command aborted. If the host attempts to write to a read 
only (RO) log address, the device shall return command aborted. 


pRegister 7 GT a 


DC 7=1 Reserved 
DC 7=1 Reserved 
DC 7=1 Reserved 


DC 7=1 Reserved 
| Status | BSY | DRDY [| DF | na_ | DRQ [ na _| na _ | ERR | 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 


cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
IDNF shall be set to one if the log sector’s ID field was not found or data structure checksum error 
occurred. 
ABRT shall be set to one if this command is not supported, if the feature associated with the log 
specified in the LBA Low register is not supported or not enabled, or if other register values are 
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invalid. ABRT may be set to one if the device is not able to complete the action requested by the 
command. 
Device/Head register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one indicating that the device is capable of receiving any command. 
DF (Device Fault) shall be set to one indicating that a device fault has occurred. 
DRQ shall be cleared to zero indicating that there is no data to be transferred. 
ERR shall be set to one if any Error register bit is set to one. 


6.64.7 Prerequisites 
DRDY set to one. 
6.64.8 Description 


This command writes a specified number of 512 byte data sectors to the specified log. The device shall 
interrupt for each DRQ block transferred. 
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6.65 WRITE MULTIPLE 
6.65.1 Command code 
C5h 

6.65.2 Feature set 


General feature set 


— Mandatory for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.65.3 Protocol 
PIO data-out (See Clause 11). 
6.65.4 Inputs 


The LBA Mid, LBA High, Device, and LBA Low specify the starting sector address to be written. The Sector 
Count register specifies the number of sectors to be transferred. 


| Register | 7] OT GT a 


LBA Mid LBA (15:8) 
LBA High LBA (23:16) 
LBA (27:24) 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors shall be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.65.5 Normal outputs 


| Register | 7] | 6 OT a 


LBA High na 
Status 
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Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.65.6 Error outputs 
An unrecoverable error encountered during the execution of this command results in the termination of the 


command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register | 7] | 6 Ta 


| Status | BSY | DRDY [| DF | na | ORQ | na | na_{ ERR | 


Error register - 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.65.7 Prerequisites 


DRDY set to one. If bit 8 of IDENTIFY DEVICE data word 59 is cleared to zero, a successful SET MULTIPLE 
MODE command shall proceed a WRITE MULTIPLE command. 


6.65.8 Description 


This command writes the number of sectors specified in the Sector Count register. 
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The number of sectors per block is defined by the content of word 59 of the IDENTIFY DEVICE response. 
The device shall interrupt for each DRQ block transferred. 


When the WRITE MULTIPLE command is issued, the Sector Count register contains the number of sectors 
(not the number of blocks) requested. 


If the number of requested sectors is not evenly divisible by the block count, as many full blocks as possible 
are transferred, followed by a final, partial block transfer. The partial block transfer is for n sectors, where: 


n = Remainder (sector count/ block count). 


If the WRITE MULTIPLE command is received when WRITE MULTIPLE commands are disabled, the Write 
Multiple operation shall be rejected with command aborted. 


Device errors encountered during WRITE MULTIPLE commands are posted after the attempted device write 
of the block or partial block transferred. The command ends with the sector in error, even if the error was in 
the middle of a block. Subsequent blocks are not transferred in the event of an error. 


The contents of the Command Block Registers following the transfer of a data block that had a sector in error 


are undefined. The host should retry the transfer as individual requests to obtain valid error information. 
Interrupt pending is set when the DRQ bit is set to one at the beginning of each block or partial block. 
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6.66 WRITE MULTIPLE EXT 
6.66.1 Command code 

39h 

6.66.2 Feature set 

48-bit Address feature set 


— Mandatory for devices implementing the 48-bit Address feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.66.3 Protocol 
PIO data-out (See Clause 11). 


6.66.4 Inputs 


Register eS oe a ah ee _ 
Features Current Reserved 

Previous Reserved 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current 

Previous 


Previous LBA (39:32 
Previous LBA (47:40 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). OO000h in the Sector Count register 
specifies that 65,536 sectors are to be transferred. 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.66.5 Normal outputs 


pRegister CT CZ 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.66.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


[Register =| OT UT a | a 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
WP shall be set to one if the media in a removable media device is write protected. 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
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MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.66.7 Prerequisites 


DRDY set to one. If bit 8 of IDENTIFY DEVICE data word 59 is cleared to zero, a successful SET MULTIPLE 
MODE command shall proceed a WRITE MULTIPLE EXT command. 


6.66.8 Description 
This command writes the number of sectors specified in the Sector Count register. 


The number of sectors per block is defined by the content of word 59 in the IDENTIFY DEVICE response. 
The device shall interrupt for each DRQ block transferred. 


When the WRITE MULTIPLE EXT command is issued, the Sector Count register contains the number of 
sectors (not the number of blocks) requested. 


If the number of requested sectors is not evenly divisible by the block count, as many full blocks as possible 
are transferred, followed by a final, partial block transfer. The partial block transfer is for n sectors, where: 


n = Remainder (sector count / block count). 


If the WRITE MULTIPLE EXT command is received when WRITE MULTIPLE EXT commands are disabled, 
the Write Multiple operation shall be rejected with command aborted. 


Device errors encountered during WRITE MULTIPLE EXT commands are posted after the attempted device 


write of the block or partial block transferred. The command ends with the sector in error, even if the error 
was in the middle of a block. Subsequent blocks are not transferred in the event of an error. 
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The contents of the Command Block Registers following the transfer of a data block that had a sector in error 
are undefined. The host should retry the transfer as individual requests to obtain valid error information. 
Interrupt pending is set when the DRQ bit is set to one at the beginning of each block or partial block. 
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6.67 WRITE MULTIPLE FUA EXT 
6.67.1 Command code 

CEh 

6.67.2 Feature set 

48-bit Address feature set 


— Optional for devices implementing the 48-bit Address feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.67.3 Protocol 
PIO data-out (See Clause 11). 


6.67.4 Inputs 


WRegister——— = eS ae a ae ee _ 
Features Current Reserved 

Previous Reserved 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current 

Previous 


Previous LBA (39:32 
Previous LBA (47:40 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). OO000h in the Sector Count register 
specifies that 65,536 sectors are to be transferred. 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.67.5 Normal outputs 


pRegister Cd CT 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 


LBA High Reserved 
Reserved 


Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.67.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


[Register =| OT UT a | a 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
WP shall be set to one if the media in a removable media device is write protected. 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
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MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.67.7 Prerequisites 


DRDY set to one. If bit 8 of IDENTIFY DEVICE data word 59 is cleared to zero, a successful SET MULTIPLE 
MODE command shall proceed a WRITE MULTIPLE FUA EXT command. 


6.67.8 Description 
The WRITE MULTIPLE FUA EXT command provides the same function as the WRITE MULTIPLE EXT 


command except that regardless of whether write caching in the device is enabled or not, the user data shall 
be written to the media before ending status for the command is reported. 
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6.68 WRITE SECTOR(S) 
6.68.1 Command code 

30h 

6.68.2 Feature set 

General feature set 


— Mandatory for devices not implementing the PACKET Command feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.68.3 Protocol 
PIO data-out (See Clause 11). 
6.68.4 Inputs 


The LBA Mid, LBA High, Device, and LBA Low specify the starting sector address to be written. The Sector 
Count register specifies the number of sectors to be transferred. 


| Register =| 7 | 6 7 5 |] 4 | 38 | 2] | at 


Sector Count - 
number of sectors to be transferred. A value of OOh specifies that 256 sectors are to be transferred. 
LBA Low - 
starting LBA bits (7:0). 
LBA Mid - 
starting LBA bits (15:8). 
LBA High - 
starting LBA bits (23:16). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
bits (3:0) starting LBA bits (27:24). 


6.68.5 Normal outputs 


| Register | 7] | GT Sa a 


| Status | BSY | DRDY [| DF | na | ORQ | na | na _{ ERR | 
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Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.68.6 Error outputs 
An unrecoverable error encountered during the execution of this command results in the termination of the 


command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register | 7] | 6 Ta 


| Status | BSY | DRDY [| DF | na | ORQ | na | na_{ ERR | 


Error register - 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able 
to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low, LBA Mid, LBA High, Device - 
shall be written with the address of first unrecoverable error. 
DEV shall indicate the selected device. 

Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to Zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.68.7 Prerequisites 
DRDY set to one. 
6.68.8 Description 


This command writes from 1 to 256 sectors as specified in the Sector Count register. A sector count of O 
requests 256 sectors. The device shall interrupt for each DRQ block transferred. 
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6.69 WRITE SECTOR(S) EXT 
6.69.1 Command code 

34h 

6.69.2 Feature set 

48-bit Address feature set 


— Mandatory for devices implementing the 48-bit Address feature set. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.69.3 Protocol 
PIO data-out (See Clause 11). 


6.69.4 Inputs 


Register — = Ss 6 | 8 ee 
Features Current Reserved 
Previous Reserved 
Sector Count | Current Sector count (7:0) 
Previous Sector count (15:8) 
LBA Low Current LBA (7:0) 
Previous LBA (31:24) 
LBA Mid Current LBA (15:8) 
Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40 


34h 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous is the value that was in the register before the most recent write to the register. 


Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 
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6.69.5 Normal outputs 


[Register S| 7? Tl UT LUT A 2 
Sector Count | HOB =0 Reserved 
LBA Low Reserved 
Reserved 
LBA Mid Reserved 
Reserved 
LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = O indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
DF (Device Fault) shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 


6.69.6 Error outputs 


An unrecoverable error encountered during the execution of this command results in the termination of the 
command. The Command Block registers contain the address of the sector where the first unrecoverable 
error occurred. The amount of data transferred is indeterminate. 


| Register = 7 es a 8 eo | 
Sector Count | HOB =0 Reserved 
Reserved 
LBA Low LBA (7:0) 
LBA (31:24) 
LBA Mid LBA (15:8) 
LBA (39:32) 
LBA High LBA (23:16) 
LBA (47:40) 
Reserved 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 
WP shall be set to one if the media in a removable media device is write protected. 
MC shall be set to one if the media in a removable media device changed since the issuance of the 
last command. The device shall clear the device internal media change detected state. 
IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if 
an address outside of the range of user-accessible addresses is requested if command 
aborted is not returned. 
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MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is 
not able to complete the action requested by the command. ABRT shall be set to one if an 
address outside of the range of user-accessible addresses is requested if IDNF is not set to 
one. 

NM shall be set to one if no media is present in a removable media device. 

LBA Low - 

LBA (7:0) of the address of the first unrecoverable error when read with Device Control register HOB 

bit cleared to zero. 

LBA (31:24) of the address of the first unrecoverable error when read with Device Control register 

HOB bit set to one. 
LBA Mid - 
LBA (15:8) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (39:32) of the address of the first unrecoverable error when read with Device Control 
register HOB bit set to one. 
LBA High - 
LBA (23:16) of the address of the first unrecoverable error when read with Device Control register 
HOB bit cleared to zero. 
LBA (47:40) of the address of the first unrecoverable error when read with Device Control register 
HOB bit set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

DF (Device Fault) shall be set to one if a device fault has occurred. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one. 


6.69.7 Prerequisites 
DRDY set to one. 
6.69.8 Description 


This command writes from 1 to 65,536 sectors as specified in the Sector Count register. A sector count 
value of 0000h requests 65,536 sectors. The device shall interrupt for each DRQ block transferred. 
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6.70 WRITE STREAM DMA EXT 
6.70.1 Command code 

3Ah 

6.70.2 Feature set 


— Mandatory if the Streaming feature set is implemented 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.70.3 Protocol 
DMA (See Clause 11) 


6.70.4 Inputs 


Register —__{|_7 | e_{| sj 4j 3 fe {af 
Features Current URG Stream ID 

Previous Sanita Completion Tine Limit (7:0) 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current LBA (7:0) 

Previous LBA (31:24) 

LBA Mid Current LBA (15:8) 


Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous Is the value that was in the register before the most recent write to the register. 


Features register current - 
URG specifies an urgent transfer request. The Urgent bit specifies that the command should be 
completed in the minimum possible time by the device and shall be completed within the specified 
Command Completion Time Limit. This bit is optional (See 6.17.42). 


WC specifies that the Write Continuous mode enabled. If the Write Continuous bit is set to one, the 
device shall not stop execution of the command due to errors. 
If the WC bit is set to one and errors occur in the transfer or writing of the data, the device shall 
continue to transfer the amount of data requested and then provide ending status with the BSY bit 
cleared to zero, the SE bit set to one, the ERR bit cleared to zero, and the type of error, ICRC, IDNF, 
or ABRT, reported in the error log. 
If the WC bit is set to one and the Command Completion Time Limit expires, the device shall stop 
execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit set 
to one, the ERR bit cleared to zero, and report the fact that the Command Completion Time Limit 
expired by setting the CCTO bit in the error log to one. 
In all cases, the device shall attempt to transfer the amount of data requested within the Comand 
Completion Time Limit even if some data transferred is in error. 

F specifies that all data for the specified stream shall be flushed to the media before command complete 
is reported when set to one. 

HSE (Handle Streaming Error) specifies that this command starts at the LBA of the last reported error 
for this stream, so the device may attempt to continue its corresponding error recovery sequence 
where it left off earlier. 
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Stream ID specifies the stream being written. The device shall operate according to the Stream ID set by 
the WRITE STREAM command. Any write of the device media or internal device buffer management 
as a result of the Stream ID is device vendor specific. 

Features register previous - 
The time allowed for the current command’s completion is calculated as follows: 
Command Completion Time Limit = (content of the Features register Previous) * 
(IDENTIFY DEVICE data words (99:98)) microseconds 
If the valtCONFIGURE STREAM command for this Stream ID. If the Default Command Completion 
Time Limit is zero, or no previous Configure Stream command was defined for this Stream ID, the 
result is vendor specific. The time is measured from the write of the command register to the final 
INTRQ for command completion 
Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
LBA shall be set to one. 
DEV shall specify the selected device. 


6.70.5 Normal Outputs 


|Register i (stC(‘i;L( CZ CU] CShCU| UCM CUACT 3 | 2 Tt CT 
Sector Count | HOB =0 Reserved 
HOB=1 Reserved 
LBA Low Reserved 


Reserved 
LBA Mid = Reserved 


Reserved 


LBA High Reserved 
Reserved 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SE shall be cleared to zero. 
DRQ shall be cleared to zero. 
ERR shall be cleared to zero. 
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6.70.6 Error Outputs 


If the WC bit is cleared to zero, the content of the registers shall be as shown below. If the WC bit is set to 
one, the SE bit shall be set to one, the ERR bit shall be cleared to zero, and the content of the Error register 
shown below shall be placed in the error log. 


[Register | ZT 6 UT CT A | 8 UT 2 a 
HOB =1 Length of Stream Error (15:8) 
LBA Low LBA (7:0) 


LBA (31:24) 
LBA Mid LBA (15:8) 


LBA High HOB =0 LBA (23:16) 
HOB = 1 LBA (47:40) 
Reserved 
DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

ICRC shall be set to one if an interface CRC error has occurred during an Ultra DMA data transfer. The 
content of this bit is not applicable for Multiword DMA transfers. 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the last 
command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if an 
address outside of the range of user-accessible addresses is requested if command aborted is not 
returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported or if an error, including an ICRC error, has 
occurred during an Ultra DMA data transfer. ABRT may be set to one if the device is not able to 
complete the action requested by the command. ABRT shall be set to one if an address outside of 
the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

CCTO (Command Completion Time Limit Out) bit shall be set to one if a Command Completion Time 
Limit Out error has occurred. 

Sector Count Current - 

bits (7:0) number of contiguous sectors containing potentially bad data, beginning with the LBA of the 

first sector with an uncorrectable error. 
Sector Count Previous - 

bits (15:8) of the number of contiguous sectors containing potentially bad data, starting at the address of 

the first uncorrectable error 
LBA Low Current - 

bits (7:0) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA Low Previous - 

bits (31:24) of the address of the first uncorrectable error when read with Device Control register HOB 

set to one. 
LBA Mid Current- 

bits (15:8) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA Mid Previous- 
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bits (39:32) of the address of the first uncorrectable error when read with Device Control register HOB 

set to one. 
LBA High Current - 

bits (23:16) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA High Current - 
bits (47:40) of the address of the first uncorrectable error when read with Device Control register HOB 
set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

SE (Stream Error) shall be set to one if an error has occurred during the execution of the command and 
the WC bit is set to one. In this case the LBA returned in the Sector Number registers shall be the 
address of the first sector in error, and the Sector Count registers shall contain the number of 
consecutive sectors that may contain errors. If the WC bit is set to one when the command is issued 
and an ICRC, IDNF, ABRT, or CCTO error occurs, the SE bit shall be set to one, the ERR bit shall 
be cleared to zero, and the bits that would normally be set in the Error register shall be set in the 
error log. 

DWE shall be set to one if an error was detected in a deferred write to the media. This error is from a 
previously issued command. If DWE is set to one, the location of the deferred error is only reported 
in the Write Stream error log. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one and the WC bit is cleared to zero. If the WC 
bit is set to one when the command is issued and an ICRC, IDNF, ABRT, or CCTO error occurs, the 
SE bit shall be set to one, the ERR bit shall be cleared to zero, and the bits that would normally be 
set in the Error register shall be set in the error log. 


6.70.7 Prerequisites 
DRDY set equal to one and BUSY cleared to zero. 
6.70.8 Description 


The Write Stream DMA EXT command allows the host to write data using the DMA data transfer protocol. 
This command allows for the host to specify to the device that additional actions need to be performed prior 
to the completion of the command if the required bits are set. 


If the Write Continuous bit is set to one,the device shall not stop execution of the command due to errors. If 
the WC bit is set to one and errors occur in the transfer or writing of the data, the device shall continue to 
transfer the amount of data requested and then provide ending status with the BSY bit cleared to zero, the 
SE bit set to one, the ERR bit cleared to zero, and the type of error, ICRC, IDNF, or ABRT, reported in the 
error log. If the WC bit is set to one and the Command Completion Time Limit expires, the device shall stop 
execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit set to one, 
the ERR bit cleared to zero, and report the fact that the Command Completion Time Limit expired by setting 
the CCTO bit in the error log to one. In all cases, the device shall attempt to transfer the amount of data 
requested within the Comand Completion Time Limit even if some data transferred is in error. 
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6.71 WRITE STREAM EXT 
6.71.1 Command code 

3Bh 

6.71.2 Feature set 


— Mandatory if the Streaming feature set is implemented. 
— Use prohibited for devices implementing the PACKET Command feature set. 


6.71.3 Protocol 
PIO data-out (See Clause 11) 


6.71.4 Inputs 


Register —__{|_7 | e_| sj aj 3 fe to 
Features Current URG Stream ID 

Previous Sanita Completion Tine Limit (7:0) 

Sector Count | Current Sector count (7:0) 

Previous Sector count (15:8) 

LBA Low Current LBA (7:0) 

Previous LBA (31:24) 

LBA Mid Current LBA (15:8) 


Previous LBA (39:32) 
LBA High Current LBA (23:16) 
Previous LBA (47:40) 


NOTE — The value indicated as Current is the value most recently written to the register. The value 
indicated as Previous Is the value that was in the register before the most recent write to the register. 


Features register current - 
URG specifies an urgent transfer request. The Urgent bit specifies that the command should be 
completed in the minimum possible time by the device and shall be completed within the specified 
Command Completion Time Limit. This bit is optional (See 6.17.42). 


WC specifies Write Continuous mode enabled. If the Write Continuous bit is set to one, the device shall 
not stop execution of the command due to errors. 
If the WC bit is set to one and errors occur in the transfer or writing of the data, the device shall 
continue to transfer the amount of data requested and then provide ending status with the BSY bit 
cleared to zero, the SE bit set to one, the ERR bit cleared to zero, and the type of error, IDNF, or 
ABRT, reported in the error log. 
If the WC bit is set to one and the Command Completion Time Limit expires, the device shall stop 
execution of the command and provide ending status with the BSY bit cleared to zero, the SE bit set 
to one, the ERR bit cleared to zero, and report the fact that the Command Completion Time Limit 
expired by setting the CCTO bit in the error log to one. 
In all cases, the device shall attempt to transfer the amount of data requested within the Comand 
Completion Time Limit even if some data transferred is in error. 

F specifies that all data for the specified stream shall be flushed to the media before command complete 
is reported when set to one. 

HSE (Handle Streaming Error) s that this command starts at the LBA of the last reported error for this 
stream, so the device may attempt to continue its corresponding error recovery sequence where it 
left off earlier. 
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Stream ID specifies the stream being written. The device shall operate according to the Stream ID set by 
the WRITE STREAM command. Any write of the device media or internal device buffer management 
as a result of the Stream ID is device vendor specific. 

Features register previous - 
The time allowed for the current command’s completion is calculated as follows: 
Command Completion Time Limit = (content of the Features register Previous) * 
(IDENTIFY DEVICE data words (99:98)) microseconds 
If the value is zero, the device shall use the Default Command Completion Time Limit supplied with a 
previous CCONFIGURE STREAM command for this Stream ID. If the Default Command Completion 
Time Limit is zero, or no previous CONFIGURE STREAM command was defined for this Stream ID, 
the result is vendor specific. The time is measured from the write of the command register to the final 
INTRQ for command completion 
Sector Count Current - 
number of sectors to be transferred low order, bits (7:0). 
Sector Count Previous - 
number of sectors to be transferred high order, bits (15:8). 
LBA Low Current - 
LBA (7:0). 
LBA Low Previous - 
LBA (31:24). 
LBA Mid Current - 
LBA (15:8). 
LBA Mid Previous - 
LBA (39:32). 
LBA High Current - 
LBA (23:16). 
LBA High Previous - 
LBA (47:40). 
Device - 
the LBA bit shall be set to one to specify the address is an LBA. 
DEV shall specify the selected device. 


6.71.5 Normal Outputs 


fRegister CUT CT UT CCT UTC U4 UT 2 
Sector Count | HOB =0 Reserved 
HOB=1 Reserved 
LBA Low Reserved 


Reserved 
LBA Mid = Reserved 


Reserved 


LBA High Reserved 
Reserved 


Status DRQ 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Reserved 


Device register - 
DEV shall indicate the selected device. 
Status register - 
BSY shall be cleared to zero indicating command completion. 
DRDY shall be set to one. 
SE shall be cleared to zero. 
DRQ shall be cleared to zero. 
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ERR shall be cleared to zero. 


6.71.6 Error Outputs 


If the WC bit is cleared to zero, the content of the registers shall be as shown below. If the WC bit is set to 
one, the SE bit shall be set to one, the ERR bit shall be cleared to zero, and the content of the Error register 
shown below shall be placed in the error log. 


|Register ET GS a 


HOB=1 Length of Stream Error (15:8 
HOB=1 LBA (31:24 
LBA Mid LBA (15:8) 


LBA (39:32) 
LBA High LBA (23:16) 


Reserved 
| Status | BSY | DRDY [| SE | DWE | DRQ | na _[ na _| 
NOTE — HOB = 0 indicates the value read by the host when the HOB bit of the Device Control register is 
cleared to zero. HOB = 1 Indicates the value read by the host when the HOB bit of the Device Control 
register is set to one. 


Error register - 

WP shall be set to one if the media in a removable media device is write protected. 

MC shall be set to one if the media in a removable media device changed since the issuance of the last 
command. The device shall clear the device internal media change detected state. 

IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if an 
address outside of the range of user-accessible addresses is requested if command aborted is not 
returned. 

MCR shall be set to one if a media change request has been detected by a removable media device. 
This bit is only cleared by a GET MEDIA STATUS or a media access command. 

ABRT shall be set to one if this command is not supported. ABRT may be set to one if the device is not 
able to complete the action requested by the command. ABRT shall be set to one if an address 
outside of the range of user-accessible addresses is requested if IDNF is not set to one. 

NM shall be set to one if no media is present in a removable media device. 

CCTO (Command Completion Time Limit Out) bit shall be set to one if a Command Completion Time 
Limit Out error has occurred. 

Sector Count Current - 

bits (7:0) number of contiguous sectors containing potentially bad data, beginning with the LBA of the 

first sector with an uncorrectable error. 
Sector Count Previous - 

bits (15:8) of the number of contiguous sectors containing potentially bad data, starting at the address of 

the first uncorrectable error 
LBA Low Current - 

bits (7:0) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA Low Previous - 
bits (31:24) of the address of the first uncorrectable error when read with Device Control register HOB 
set to one. 
LBA Mid Current- 
bits (15:8) of the address of the first uncorrectable error when read with Device Control register HOB 
cleared to zero. 
LBA Mid Previous- 

bits (39:32) of the address of the first uncorrectable error when read with Device Control register HOB 

set to one. 
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LBA High Current - 

bits (23:16) of the address of the first uncorrectable error when read with Device Control register HOB 

cleared to zero. 
LBA High Current - 
bits (47:40) of the address of the first uncorrectable error when read with Device Control register HOB 
set to one. 
Device register - 
DEV shall indicate the selected device. 
Status register - 

BSY shall be cleared to zero indicating command completion. 

DRDY shall be set to one. 

SE (Stream Error) shall be set to one if an error has occurred during the execution of the command and 
the WC bit is set to one. In this case the LBA returned in the Sector Number registers shall be the 
address of the first sector in error, and the Sector Count registers shall contain the number of 
consecutive sectors that may contain errors. If the WRC bit is set to one when the command is 
issued and an IDNF, ABRT, or CCTO error occurs, the SE bit shall be set to one, the ERR bit shall 
be cleared to zero, and the bits that would normally be set in the Error register shall be set in the 
error log. 

DWE shall be set if an error was detected in a deferred write to the media. This error is from a previously 
issued command. If DWE is set to one, the location of the deferred error is only reported in the Write 
Strean error log. 

DRQ shall be cleared to zero. 

ERR shall be set to one if an Error register bit is set to one and the WC bit is cleared to zero. If the WC 
bit is set to one when the command is issued and an IDNF, ABRT, or CCTO error occurs, the SE bit 
shall be set to one, the ERR bit shall be cleared to zero, and the bits that would normally be set in 
the Error register shall be set in the error log. 


6.71.7 Prerequisites 
DRDY set equal to one and BUSY cleared to zero. 
6.71.8 Description 


This command writes from 1 to 65,536 sectors as specified in the Sector Count register. A sector count of 0 
requests 65,536 sectors. 


If the Write Continuous bit is set to one,the device shall not stop execution of the command due to errors. If 
the WC bit is set to one and errors occur in the transfer or writing of the data, the device shall continue to 
transfer the amount of data requested and then provide ending status with the BSY bit cleared to zero, the 
SE bit set to one, the ERR bit cleared to zero, and the type of error, IDNF, or ABRT, reported in the error log. 
If the WC bit is set to one and the Command Completion Time Limit expires, the device shall stop execution 
of the command and provide ending status with the BSY bit cleared to zero, the SE bit set to one, the ERR 
bit cleared to zero, and report the fact that the Command Completion Time Limit expired by setting the 
CCTO bit in the error log to one. In all cases, the device shall attempt to transfer the amount of data 
requested within the Comand Completion Time Limit even if some data transferred is in error. 
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7 Parallel interface physical and electrical requirements (See Volume 2) 
8 Parallel interface signal assignments and descriptions (See Volume 2) 


9 Parallel interface general operating requirements of the physical, data link, and 
transport layers (See Volume 2) 


10 Parallel interface register addressing (See Volume 2) 

11 Parallel interface transport Protocols (See Volume 2) 

12 Parallel interface timing (See Volume 2) 

13 Serial interface overview (See Volume 3) 

14 Serial interface physical layer (See Volume 3) 

15 Serial interface link layer (See Volume 3) 

16 Serial interface transport layer (See Volume 3) 

17 Serial interface device command layer (See Volume 3) 

18 Host command layer (See Volume 3) 

19 Serial interface host adapter register interface (See Volume 3) 


20 Serial interface error handling (See Volume 3) 
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ANNEX A. BIBLIOGRAPHY (INFORMATIVE) 


Address Offset Reserved Area Boot, INCITS TR-27:2001 

A.X. Widmer and P.A. Franaszek, “A DC-Balanced, Partitioned-Block, 8b/10b Transmission Code”. IBM 
Journal of Research and Development, 27, no. 5: 440-451 (September, 1983) 

U.S. Patent 4,486,739. Peter A. Franaszek and Albert X. Widmer. Byte Oriented DC Balanced (0,4) 8b/10b 
Partitioned Block Transmission Code. (December 4, 1984) 


ANNEX B. COMMAND SET SUMMARY (INFORMATIVE) 


The following four tables are provided to facilitate the understanding of the command set. Table 64 provides 
information on which command codes are currently defined. Table 65 provides a list of all of the commands 
in order of command code with the required use for each. Table 66 provides a summary of all commands in 
alphabetical order with the required use for each. 


Table 64 - Command Matrix 
a 
| Ox _| | fo =| LR | 


| 8x_| 
| 9x_| 
| Ax _| 
| Bx _| 


| Dx _| 
| Ex | 


C =a defined command. A=Reserved for assignment by the CompactFlash™ 

R = Reserved, undefined in current specifications. Association 

V = Vendor specific commands. M=Reserved for the Media Card Pass Through 

O = Obsolete. Command feature set. 

E=a retired command. S=Reserved for Serial ATA 

F=If the device does not implement the CFA feature * indicates that the entry in this table has changed 
set, this command code is Vendor specific. from ATA/ATAPI-6, INCITS 361-2002. 
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Table 65 - Command codes (sorted by command code) 


protocol Command Devices not Devices Command 
implementing | implementing code 
the PACKET the PACKET 
Command Command 
feature s feature set 


ND 
ND 
M 
DMQ__|READDMAQUEUEDEXT 
ND 
DMQ__| WRITEDMAQUEVEDEXT 
D 


N 


w ro[r}ry nN ro) 
rep) T1| | > o fe) 
= =e [a el bem = => 


D 
D 
D 
D 
D 


M 
M 
M 
M 
O 


P/DMQ 
ND 
ND 


ND 
ND 


ND 
ND 
ND 
ND 


DIDI DIDI DIDI DD DDD >| >/> Ol WW] ] 
FIP JE |O;/O/O/O/O;/OlO;/OINIE|O i m}O|® 
SSIS (S|5/S|/S/5|S|/S|/S|/ 5/5/15 x= s|s|> 


et 
| OO 
[p= = OF 4 
ec a 
a: 
Oe 
t= 0) 
| OO 
ac es 
| OO 
p= - 2012 2 
POG 
et a 
= Oe = 
f= = 208) 
POR 
0s 
PS 220% 5 
| OO 
DMQ WRITE DMA QUEUED FUA EXT 
P WRITE LOG EXT 
ae: ae 
ee SOE Tt 
fr =e 2 
fe Oe 
| OO 
aa 
| OO 
a ae 
a a 
a a 
—° as 
i = =O. <7) 
| OO 
a: 
ee Ol 
| 


Zz Zz 
iw) iw) 


(continued) 
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Table 65 - Command codes (sorted by command code) (continued) 


protocol Command Devices not Devices 
implementing | implementing 
the PACKET the PACKET 
Command Command 
feature set feature set 


N 
N 
DMQ 
DM 
DM 
DMQ 
M 
M 
ND 


ND SET FEATURES 


D 
D 


M 
M 
M 
M 
M 


ND 
ND 
ND 
ND 
ND 
ND 
ND 
ND 
ND 
ND 
ND 
ND 


Revision 4b 


Command 
code 


PO SECURITY SET PASSWORD 


PO SECURITY UNLOCK 
ND SECURITY ERASE PREPARE 


PO SECURITY ERASE UNIT 


ND SECURITY FREEZE LOCK 


SECURITY DISABLE PASSWORD 
ND READ NATIVE MAX ADDRESS 
ND SET MAX ADDRESS 


(continued) 
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Table 65 - Command codes (sorted by command code) (continued) 


protocol Command Devices not Devices Command 
implementing | implementing code 
the PACKET the PACKET 
Command Command 
feature set feature set 
Vendor specific V V 9Ah,COh- 
C3h,8xh, 
FOh,F7h, 
FAh-FFh 
Retired E E 11h-1Fh, 
71h-7Fh, 
94h-99h, 
DBh-DDh, 


| 7 | 


| - __| Reserved: all remaining codes 


Key: 

ND = Non-data command M = Mandatory 

PI = PIO data-in command O = Optional 

PO = PIO data-out command N = Use prohibited 

DM = DMA command V = Vendor specific implementation 

DMQ = DMA QUEUED command E = Retired 

DR = DEVICE RESET command B = Obsolete 

DD = EXECUTE DEVICE DIAGNOSTIC command R = Reserved 

P = PACKET command F=If the device does not implement the CFA feature 
set, this command code is Vendor specific. 


VS = Vendor specfic 
(concluded) 
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Table 66- Command codes (sorted by command) 
Devices not Devices Command 
implementing | implementing code 
the PACKET the PACKET 
Command Command 


DEVICE RESET N 
DOWNLOAD MICROCODE 
EXECUTE DEVICE DIAGNOSTIC M 


feature set lal 
es == SN Te So 
| UN UT CD 
ps Ne Soh 
Pe Or > 3b = si = 
| OCT Bh 
Per On = 8 Bi 
i Oe iB ihe if 
oe = 
| MT 8h 
a ee 
a 
a a = 
a ee ae ee 
a es a ol ee 
a = 
fe = NE = = 2) ED =| 
ee 
a ee ee 
ee ee 
a ee eee 
Le Oe = Reh 
a aes ee 
| MT 0h 
a a a 
| UNCUT 40h_ 
Pp NT 42h 
a eee a eee 
Ot eh 


(continued) 
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protocol 


Table 66 - Command codes (sorted by commana) (continued) 


Command 


SECURITY ERASE UNIT 


Devices not 
implementing 
the PACKET 

Command 

feature set 


Devices 
implementing 
the PACKET 
Command 
feature set 


Command 
code 


SECURITY FREEZE LOCK 


SECURITY SET PASSWORD 


SECURITY UNLOCK 


SERVICE 


SET FEATURES 


SET MAX 


ND 
SET MAX ADDRESS EXT 
SET MULTIPLE MODE 

SLEEP == 2 oe* = 2 SF 


SLEEP 
SMART DISABLE OPERATIONS 


[SMARTWRITELOG 


SMART WRITE LOG 
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Table 66 - Command codes (sorted by command) (continued) 
Vendor specific 


Retired E E 
DBh-DDh, 
E9h 
ae 


Reserved: all remaining codes a [eee eens ee) 


ND = Non-data command M = Mandatory 

PI = PIO data-in command O = Optional 

PO = PIO data-out command N = Use prohibited 

DM = DMA command V = Vendor specific implementation 
DMQ = DMA QUEUED command E = Retired 

DR = DEVICE RESET command B = Obsolete 


DD = EXECUTE DEVICE DIAGNOSTIC command R = Reserved 
P = PACKET command F=If the device does not implement the CFA feature set, 


this command code is Vendor specific. 
VS = Vendor specfic 


(concluded) 
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ANNEX C. DESIGN AND PROGRAMMING CONSIDERATIONS FOR LARGE 
PHYSICAL SECTOR DEVICES (INFORMATIVE) 


C.1 Introduction 


Since the inception of the ATA interface the smallest addressable unit of data has been the 512 byte sector. 
In hard disk drives each sector has an associated error correcting code field to allow detection and correction 
of read errors. Over time, error correcting code fields have been lengthened to provide greater detection and 
correction capability. As a result, the proportion of device media devoted to ECC fields has risen. Increasing 
the length of data sectors on the media increases the efficiency of ECC by enabling better error detection 
and correction using a smaller proportion of media. 


C.2 Physical sectors 


Because the 512 byte sector has been a constant since the beginning of ATA many software changes would 
be required if device logical sectors were made larger. To preserve the legacy software that assumes a 512 
byte sector, logical addressing based on 512 byte sectors has been retained. Larger physical sectors are 
implemented as power of two multiples of 512 byte logical sectors, 1,2,4,8,16, etc. For example, devices 
may have physical sectors that are 8 logical sectors long or 4096 bytes total. It is not possible to create a 
logical sector that spans two physical sectors. 


C.3  Unaligned write 


While retaining the 512 byte logical sector maintains software compatibility it introduces a_ potential 
performance issue, unaligned write, which must be avoided. A physical sector must be written to the media 
in a single operation. To complete a write command that writes a fraction of a physical sector the device 
must read the entire physical sector into buffer memory update the buffer memory with the write data and 
then write the entire physical sector to the media. This will incur a performance penalty of at least a drive 
revolution. 


Write commands can begin mid physical sector and end mid physical sector resulting in two unaligned 
writes. In this case the device has to read both the beginning and ending physical sector of the write into the 
buffer. 


To avoid the performance penalty from an unaligned write all write operations must begin with the first sector 
of a physical sector and end with the last sector of a physical sector. 


The first logical sector must be the first 512 bytes of the first physical sector on the device. This allows a 
host to align write operations with the physical sectors. 


Supporting unaligned write operations is optional, but highly recommended to maintain backward 
compatibility with software. See IDENTIFY DEVICE 6.17. 


Figure 10 illustrates an unaligned write on a device with 2048 byte physical sectors. The first four logical 
sectors, LBAO - LBA3, reside on physical sector 0. To write only LBA3 the host sends a conventional write 
command and the data for LBA3. On receipt of the write command the device seeks to the physical sector 
that contains LBA3, which is physical sector 0. Physical sector 0 is read into the device buffer. Then the new 
write data for LBA3 is placed in the buffer, overwriting a segment of the buffer. The buffer data is then written 
to the media, physical sector 0. 
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Media Layout 


ei Physical Sector 0 Physical Sector 1 
Sector LBAO|}LBA1|LBA2|LBA3| LBA4|LBA5}LBA6| LBA8 


Device 


Unaligned Write Operation 


LBA3 
as ag: LBA 3 Write 
From Host 
Physical - 
Sector 0 Physical Sector 0 Physical Sector 1 


read from 
media tL Combined data written 


to media 


Figure 10 - Unaligned Write Example 


C.4 SET MAX 


Hosts which use the SET MAX command should set a value to the last logical sector of a physical sector to 
allow writes to the end of the user area without requiring an unaligned write. Devices should accommodate a 
SET MAX setting to any LBA address to maintain compatibility. 


C.5 Software compatibility 


While the current specification allows devices to report up to 2*° or 32,768 logical sectors per physical sector 
there are file system limitations in existing systems that restrict practical device implementations to 4096 
bytes per physical sector. 
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ANNEX D. DEVICE DETERMINATION OF CABLE TYPE (INFORMATIVE) (SEE 
VOLUME 2) 


ANNEXE. SIGNAL INTEGRITY AND UDMA GUIDE (INFORMATIVE) (SEE VOLUME 
2) 


ANNEX F. REGISTER SELECTION ADDRESS SUMMARY (INFORMATIVE) (SEE 
VOLUME 2) 


ANNEX G. SAMPLE CODE FOR CRC AND SCRAMBLING (INFORMATIVE) (SEE 
VOLUME 3) 


ANNEXH. FIS TYPE FIELD VALUE SELECTION (INFORMATIVE) (SEE VOLUME 3) 


ANNEX I. PHYSICAL LAYER IMPLEMENTATION EXAMPLES (INFORMATIVE) (SEE 
VOLUME 3) 


ANNEX J. COMMAND PROCESSING EXAMPLE (INFORMATIVE) (SEE VOLUME 3) 
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